微信小程序?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-05js調(diào)用父框架函數(shù)與彈窗調(diào)用父頁面函數(shù)的簡單方法
下面小編就為大家?guī)硪黄猨s調(diào)用父框架函數(shù)與彈窗調(diào)用父頁面函數(shù)的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11