微信小程序 避免重复自定义跳转类型和样式按钮组件

本文介绍了一个小程序自定义导航按钮组件的实现方法,通过简单的配置即可实现不同样式的按钮及跳转功能。

小程序终于可以支持自定义组件了。毕业党写一个实用的按钮组件,望指教

按照官方指导,先创建如下目录:


.json文件:

{
  "component":true
}

.js文件:

// component/mynavigate.js
Component({
  properties: {
    title: {                  //按钮文字
      type: String
    },
    url: {                  //跳转位置
      type: String
    },
    kind:{                     //跳转类型
      type:String
    },
    Mclass:{                   //按钮样式 
      type:String
    }
  },
  data: {
    disabled: false
  },
  methods: {
    _gonavigator: function () { 
      var that = this
      if (that.data.disabled)
        return;
      this.setData({ disabled: true })      //防止重复点击
      switch(that.data.kind)
      {
        case "redirect":
        wx.redirectTo({
          url: this.data.url,
       })
            break;
        case "navigate": 
        wx.navigateTo({
          url: this.data.url,
          complete: function () {               
            setTimeout(function () {
              that.setData({ disabled: false })
            }, 3000);}})
          break;
      }

    }
  }
})

.wxml文件:


{{title}}

.wxss文件:

/* component/mynavigate.wxss */
.diybtn{
  width:100%;
  height:100rpx;
  background: #1aad19;
  color:white;
  font-size:40rpx;
  text-align: center;
  line-height: 100rpx;
}
.cir{
  border-radius: 100rpx;
}
.black{
  background:#353535;
}
.long-cir{
  width: 94%;
  border-radius: 100rpx;
}

以上组件代码完毕,接下来就是在需要它的页面上引用了。

在引用的.json文件里:


{
"usingComponents":{
"自己取名字":"/component/navigate/navigate"
}
}

在引用的.wxml文件里:


<自己去的组件名 title="领取代金券" Mclass="diybtn black long-cir" url="/pages/redeem/index" kind="navigate" />

不错,就这么一句。代码看着清爽多了。

在引用的.wxss文件里:


自己取的组件名{ // 这里相当于在组件外面的一个view
display:flex;
width:100%;
box-sizing:border-box;
margin-top:10rpx;
justify-content: center;
}

这是效果


用起来很方便,组件内的样式在组件的wxss里改,换个class名就好了


不知道为什么会有这个报错,请各位留言指点

转载于:https://juejin.im/post/5a013319f265da43310d39b1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值