小程序模拟实现单选多选功能,自定义样式

小程序的单选组件radio和多选组件checkbox的样式只提供更改颜色,这对实际项目中的需求显然是不够的,所以我就自己模拟实现一个。

踩坑点:小程序不支持操作dom

1,模拟实现多选框:

实现思路:思路非常简单,给每个选项绑定checked属性,类型为布尔值,点击取反即可



  
    
      
    
     
  

/* wxss */
.wrap{
  width: 550rpx;
  margin: 50rpx auto
}

.checkbox-con{
  margin-top: 40rpx;
  text-align: center
}
.checkbox{
  width: 260rpx;
  height: 72rpx;
  line-height: 72rpx;
  font-size: 28rpx;
  color: #888888;
  border: 1rpx solid #CECECE;
  border-radius: 5rpx;
  display: inline-block;
  margin: 0 10rpx 20rpx 0;
  position: relative
}
.checked{
  color: #1A92EC;
  background: rgba(49,165,253,0.08);
  border: 1rpx solid #31A5FD;
}
.checkbox checkbox{
  display: none
}
.checked-img{
  width: 28rpx;
  height: 28rpx;
  position: absolute;
  top: 0;
  right: 0
}

 



Page({
  data: {
    checkboxArr: [{
      name: '选项A',
      checked: false
    }, {
      name: '选项B',
      checked: false
    }, {
      name: '选项C',
      checked: false
    }, {
      name: '选项D',
      checked: false
    }, {
      name: '选项E',
      checked: false
    }, {
      name: '选项F',
      checked: false
    }],
  },
  checkbox: function (e) {
    var index = e.currentTarget.dataset.index;//获取当前点击的下标
    var checkboxArr = this.data.checkboxArr;//选项集合
    checkboxArr[index].checked = !checkboxArr[index].checked;//改变当前选中的checked值
    this.setData({
      checkboxArr: checkboxArr
    });
  },
  checkboxChange: function (e) {
    var checkValue = e.detail.value;
    this.setData({
      checkValue: checkValue
    });
  },
  confirm: function() {// 提交
    console.log(this.data.checkValue)//所有选中的项的value
  },
})

搞定~

2,模拟实现单选框

思路:这个和多选差不多,区别就是需要在点击时清空其他项的选中状态,然后再把当前项设置为选中状态

代码也差不多

wxml的话就把check-group标签改为radio-group; js那边就在点击时多加个判断



  
    
      
    
     
  

 



Page({
  data: {
    checkboxArr: [{
      name: '选项A',
      checked: false
    }, {
      name: '选项B',
      checked: false
    }, {
      name: '选项C',
      checked: false
    }, {
      name: '选项D',
      checked: false
    }, {
      name: '选项E',
      checked: false
    }, {
      name: '选项F',
      checked: false
    }],
  },
  radio: function (e) {
    var index = e.currentTarget.dataset.index;//获取当前点击的下标
    var checkboxArr = this.data.checkboxArr;//选项集合
    if (checkboxArr[index].checked) return;//如果点击的当前已选中则返回
    checkboxArr.forEach(item => {
      item.checked = false
    })
    checkboxArr[index].checked = true;//改变当前选中的checked值
    this.setData({
      checkboxArr: checkboxArr
    });
  },
  radioChange: function (e) {
    var checkValue = e.detail.value;
    this.setData({
      checkValue: checkValue
    });
  },
  confirm: function() {// 提交
    console.log(this.data.checkValue)//所有选中的项的value
  },
})

最后上个效果截图

小程序模拟实现单选多选功能,自定义样式_第1张图片

你可能感兴趣的:(微信小程序)