微信小程序?qū)崿F(xiàn)單選、多選及如何通過變量控制單選/多選功能
一、實現(xiàn)單選功能
微信小程序提供了 radio 組件來實現(xiàn)單選功能。radio 組件需要配合 radio-group 使用。
1. WXML 代碼
<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 代碼
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; // 更新選中狀態(tài)
return item;
});
this.setData({ items });
console.log('選中的值:', value);
}
});3. 實現(xiàn)效果


- 用戶只能選擇一個選項。
- 選中的值會通過
onRadioChange事件返回。
二、實現(xiàn)多選功能
微信小程序提供了 checkbox 組件來實現(xiàn)多選功能。checkbox 組件需要配合 checkbox-group 使用。
1. WXML 代碼
<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
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; // 獲取選中的值數(shù)組
const items = this.data.items.map(item => {
item.checked = values.includes(item.value); // 更新選中狀態(tài)
return item;
});
this.setData({ items });
console.log('選中的值:', values);
}
});3. 實現(xiàn)效果


- 用戶可以選擇多個選項。
- 選中的值會通過
onCheckboxChange事件返回一個數(shù)組。
三、自定義單選和多選
如果你不想使用 radio 或 checkbox 組件,可以通過自定義邏輯實現(xiàn)單選和多選功能。
1. WXML 代碼
<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
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 代碼
.container {
padding: 20px;
}
.item {
padding: 10px;
margin-bottom: 10px;
border: 1px solid #ccc;
text-align: center;
}
.active {
background-color: #07c160;
color: white;
}4. 實現(xiàn)效果
單選



多選



- 點擊選項時,根據(jù)
isMultiple的值決定是單選還是多選。 - 選中的選項會高亮顯示。
四、總結(jié)
| 功能 | 使用組件 | 特點 |
|---|---|---|
| 單選 | radio + radio-group | 只能選擇一個選項 |
| 多選 | checkbox + checkbox-group | 可以選擇多個選項 |
| 自定義選擇 | 無組件,通過邏輯實現(xiàn) | 更靈活,可以自定義樣式和交互邏輯 |
到此這篇關(guān)于微信小程序?qū)崿F(xiàn)單選、多選及如何通過變量控制單選/多選功能的文章就介紹到這了,更多相關(guān)微信小程序單選多選內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS面向?qū)ο蟮某绦蛟O計相關(guān)知識小結(jié)
這篇文章主要介紹了JS面向?qū)ο蟮某绦蛟O計,現(xiàn)在很多代碼都是基于面向?qū)ο髮崿F(xiàn),需要的朋友可以參考下2018-05-05
js調(diào)用父框架函數(shù)與彈窗調(diào)用父頁面函數(shù)的簡單方法
下面小編就為大家?guī)硪黄猨s調(diào)用父框架函數(shù)與彈窗調(diào)用父頁面函數(shù)的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11

