微信小程序 checkbox 实现双向绑定以及特殊交互处理

wxml文件代码如下:

html 复制代码
<!--页面顶部 引入wxs文件-->
<wxs module="tools" src="../../filter/tools.wxs"></wxs>
...
<checkbox-group bindchange="checkboxChange">
  <label class="weui-cell weui-check__label" wx:for="{{cancerItems}}" wx:key="value">
    <view class="weui-cell__hd">
      <checkbox value="{{item.value}}" checked="{{tools.getIncludes(checkedCancers, item.value)}}"/>
    </view>
    <view class="weui-cell__bd">{{item.name}}</view>
  </label>
</checkbox-group>

js代码如下:

javascript 复制代码
Page({
	data: {
		// 癌种
		cancerItems: [
		  {value: 'fou', name: '否'},
		  {value: 'fei', name: '肺癌'},
		  {value: 'ruxian', name: '乳腺癌'},
		  {value: 'wei', name: '胃癌'},
		  {value: 'gan', name: '肝癌'},
		  {value: 'qita', name: '其他'}
		],
		checkedCancers: [], // 选择的癌种
	},
	checkboxChange (event) {
	  console.log('event', event)
	  let checkedVal = event.detail.value
	  if (checkedVal[checkedVal.length - 1] === 'fou') { // 如果用户选择了"否",则其他癌种清空
	    checkedVal = ['fou']
	  } else { // 如果选择癌种或者"其他","否"取消选择
	    const index = checkedVal.indexOf('fou')
	    if (index > -1) {
	      checkedVal.splice(index, 1)
	    }
	    if (checkedVal.includes('fou')) { // 如果选择"其他"
	      //
	    }
	  }
	  this.setData({
	    checkedCancers: checkedVal
	  })
	}
})

所谓tool.getIncludes 方法需要 引入 tool.wxs 文件

文件代码如下:

javascript 复制代码
var tools = {
	getIncludes: function(val, target) {
	    if(!val) return
	    if(val.indexOf(target) > -1) {
	      	return true
	    } else {
	      	return false
	    }
	}
}
module.exports = {
	getIncludes: tools.getIncludes
}

注:微信小程序提到:WXS(WeiXin Script)是内联在 WXML 中的脚本段。通过 WXS 可以在模版中内联少量处理脚本,丰富模板的数据预处理能力。另外, WXS 还可以用来编写简单的 WXS 事件响应函数

相关推荐
知识分享小能手9 小时前
uni-app 入门学习教程,从入门到精通,uni-app组件 —— 知识点详解与实战案例(4)
前端·javascript·学习·微信小程序·小程序·前端框架·uni-app
韩立学长12 小时前
基于微信小程序的公益捐赠安全平台9hp4t247 包含完整开发套件(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·微信小程序·小程序
亮子AI1 天前
【小程序】微信小程序点击效果(view、button、navigator)
微信小程序·小程序
Q_Q5110082851 天前
python+uniapp基于微信小程序团购系统
spring boot·python·微信小程序·django·uni-app·node.js·php
炒毛豆1 天前
uniapp微信小程序+vue3基础内容介绍~(含标签、组件生命周期、页面生命周期、条件编译(一码多用)、分包))
vue.js·微信小程序·uni-app
從南走到北1 天前
洗车小程序系统
微信小程序·小程序
namehu1 天前
前端性能优化之:图片缩放 🚀
前端·性能优化·微信小程序
dazhong20121 天前
微信小程序开发实战指南(三)-- Webview访问总结
微信小程序·小程序
盛夏绽放1 天前
关于 uni-app 与原生微信小程序中的生命周期 —— 一次“生命旅程”的解读
微信小程序·小程序·uni-app
流水线上的指令侠1 天前
使用C#写微信小程序后端——电商微信小程序
微信小程序·小程序·c#·visual studio