微信小程序:实现单选,多选,通过变量控制单选/多选

一、实现单选功能

微信小程序提供了 radio 组件来实现单选功能。radio 组件需要配合 radio-group 使用。

1. WXML 代码

html 复制代码
<radio-group bindchange="onRadioChange">
  <label wx:for="{{items}}" wx:key="id">
    <radio value="{{item.value}}" checked="{{item.checked}}" /> {{item.name}}
  </label>
</radio-group>

2. JS 代码

javascript 复制代码
Page({
  data: {
    items: [
      { id: 1, name: '选项A', value: 'A', checked: false },
      { id: 2, name: '选项B', value: 'B', checked: false },
      { id: 3, name: '选项C', value: 'C', checked: false }
    ]
  },

  // 单选按钮变化事件
  onRadioChange(e) {
    const value = e.detail.value; // 获取选中的值
    const items = this.data.items.map(item => {
      item.checked = item.value === value; // 更新选中状态
      return item;
    });

    this.setData({ items });
    console.log('选中的值:', value);
  }
});

3. 实现效果

  • 用户只能选择一个选项。

  • 选中的值会通过 onRadioChange 事件返回。


二、实现多选功能

微信小程序提供了 checkbox 组件来实现多选功能。checkbox 组件需要配合 checkbox-group 使用。

1. WXML 代码

html 复制代码
<checkbox-group bindchange="onCheckboxChange">
  <label wx:for="{{items}}" wx:key="id">
    <checkbox value="{{item.value}}" checked="{{item.checked}}" /> {{item.name}}
  </label>
</checkbox-group>

2. JS 代码

javascript

javascript 复制代码
Page({
  data: {
    items: [
      { id: 1, name: '选项A', value: 'A', checked: false },
      { id: 2, name: '选项B', value: 'B', checked: false },
      { id: 3, name: '选项C', value: 'C', checked: false }
    ]
  },

  // 多选按钮变化事件
  onCheckboxChange(e) {
    const values = e.detail.value; // 获取选中的值数组
    const items = this.data.items.map(item => {
      item.checked = values.includes(item.value); // 更新选中状态
      return item;
    });

    this.setData({ items });
    console.log('选中的值:', values);
  }
});

3. 实现效果

  • 用户可以选择多个选项。

  • 选中的值会通过 onCheckboxChange 事件返回一个数组。


三、自定义单选和多选

如果你不想使用 radiocheckbox 组件,可以通过自定义逻辑实现单选和多选功能。

1. WXML 代码

html 复制代码
<view class="container">
  <view wx:for="{{items}}" wx:key="id" class="item {{item.checked ? 'active' : ''}}" bindtap="onItemTap" data-index="{{index}}">
    {{item.name}}
  </view>
</view>

2. JS 代码

javascript

javascript 复制代码
Page({
  data: {
    items: [
      { id: 1, name: '选项A', value: 'A', checked: false },
      { id: 2, name: '选项B', value: 'B', checked: false },
      { id: 3, name: '选项C', value: 'C', checked: false }
    ],
    isMultiple: false // 是否多选
  },

  // 点击选项事件
  onItemTap(e) {
    const index = e.currentTarget.dataset.index; // 获取点击的索引
    const items = this.data.items;

    if (this.data.isMultiple) {
      // 多选逻辑
      items[index].checked = !items[index].checked;
    } else {
      // 单选逻辑
      items.forEach((item, i) => {
        item.checked = i === index;
      });
    }

    this.setData({ items });
    console.log('当前选中的值:', items.filter(item => item.checked).map(item => item.value));
  }
});

3. WXSS 代码

css 复制代码
.container {
  padding: 20px;
}

.item {
  padding: 10px;
  margin-bottom: 10px;
  border: 1px solid #ccc;
  text-align: center;
}

.active {
  background-color: #07c160;
  color: white;
}

4. 实现效果

单选

多选

  • 点击选项时,根据 isMultiple 的值决定是单选还是多选。

  • 选中的选项会高亮显示。


四、总结

功能 使用组件 特点
单选 radio + radio-group 只能选择一个选项
多选 checkbox + checkbox-group 可以选择多个选项
自定义选择 无组件,通过逻辑实现 更灵活,可以自定义样式和交互逻辑
相关推荐
2501_915106327 小时前
常见 iOS 抓包工具的使用方式与组合思路
android·ios·小程序·https·uni-app·iphone·webview
说私域8 小时前
基于AI智能名片链动2+1模式S2B2C商城小程序的企业运营能力提升策略研究
大数据·人工智能·小程序·开源·流量运营
宁夏雨科网8 小时前
家电公司想开发小程序有没有现成的
小程序·家电·商城小程序·家电小程序·家电商城
计算机毕设指导68 小时前
基于微信小程序的咖啡店点餐系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·intellij-idea
计算机程序设计小李同学1 天前
婚纱摄影集成管理系统小程序
java·vue.js·spring boot·后端·微信小程序·小程序
幽络源小助理1 天前
SpringBoot+小程序高校素拓分管理系统源码 – 幽络源免费分享
spring boot·后端·小程序
Mr -老鬼1 天前
移动端跨平台适配技术框架:从发展到展望
android·ios·小程序·uni-app
内存不泄露1 天前
棋牌预约小程序系统论文
小程序
计算机徐师兄1 天前
Java基于微信小程序的食堂线上预约点餐系统【附源码、文档说明】
java·微信小程序·食堂线上预约点餐系统小程序·食堂线上预约点餐微信小程序·java食堂线上预约点餐小程序·食堂线上预约点餐小程序·食堂线上预约点餐系统微信小程序
说私域2 天前
短视频私域流量池的变现路径创新:基于AI智能名片链动2+1模式S2B2C商城小程序的实践研究
大数据·人工智能·小程序