小程序?qū)崿F(xiàn)單選多選功能
小程序的單選組件radio和多選組件checkbox的樣式只提供更改顏色,這對(duì)實(shí)際項(xiàng)目中的需求顯然是不夠的,所以自己模擬實(shí)現(xiàn)一個(gè)。
踩坑點(diǎn):小程序不支持操作dom
1、模擬實(shí)現(xiàn)多選框:
實(shí)現(xiàn)思路:思路非常簡(jiǎn)單,給每個(gè)選項(xiàng)綁定checked屬性,類型為布爾值,點(diǎn)擊取反即可
<!--wxml--> <view class='wrap'> <view class='checkbox-con'> <checkbox-group bindchange="checkboxChange"> <label class="{{item.checked?'checkbox checked':'checkbox'}}" wx:for="{{checkboxArr}}" bindtap='checkbox' data-index="{{index}}" wx:key="item.name"> <checkbox value="{{item.name}}" checked="{{item.checked}}"/>{{item.name}} </label> </checkbox-group> <button type='primary' bindtap='confirm'>提交</button> </view> </view>
/* 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 }
js:
Page({ data: { checkboxArr: [{ name: '選項(xiàng)A', checked: false }, { name: '選項(xiàng)B', checked: false }, { name: '選項(xiàng)C', checked: false }, { name: '選項(xiàng)D', checked: false }, { name: '選項(xiàng)E', checked: false }, { name: '選項(xiàng)F', checked: false }], }, checkbox: function (e) { var index = e.currentTarget.dataset.index;//獲取當(dāng)前點(diǎn)擊的下標(biāo) var checkboxArr = this.data.checkboxArr;//選項(xiàng)集合 checkboxArr[index].checked = !checkboxArr[index].checked;//改變當(dāng)前選中的checked值 this.setData({ checkboxArr: checkboxArr }); }, checkboxChange: function (e) { var checkValue = e.detail.value; this.setData({ checkValue: checkValue }); }, confirm: function() {// 提交 console.log(this.data.checkValue)//所有選中的項(xiàng)的value }, })
2、模擬實(shí)現(xiàn)單選框
思路:這個(gè)和多選差不多,區(qū)別就是需要在點(diǎn)擊時(shí)清空其他項(xiàng)的選中狀態(tài),然后再把當(dāng)前項(xiàng)設(shè)置為選中狀態(tài)
代碼也差不多
wxml的話就把check-group標(biāo)簽改為radio-group; js那邊就在點(diǎn)擊時(shí)多加個(gè)判斷
<!--wxml--> <view class='wrap'> <view class='checkbox-con'> <radio-group bindchange="radioChange"> <label class="{{item.checked?'checkbox checked':'checkbox'}}" wx:for="{{checkboxArr}}" bindtap='radio' data-index="{{index}}" wx:key="item.name"> <checkbox value="{{item.name}}" checked="{{item.checked}}"/>{{item.name}} </label> </radio-group> <button type='primary' bindtap='confirm'>提交</button> </view> </view>
Page({ data: { checkboxArr: [{ name: '選項(xiàng)A', checked: false }, { name: '選項(xiàng)B', checked: false }, { name: '選項(xiàng)C', checked: false }, { name: '選項(xiàng)D', checked: false }, { name: '選項(xiàng)E', checked: false }, { name: '選項(xiàng)F', checked: false }], }, radio: function (e) { var index = e.currentTarget.dataset.index;//獲取當(dāng)前點(diǎn)擊的下標(biāo) var checkboxArr = this.data.checkboxArr;//選項(xiàng)集合 if (checkboxArr[index].checked) return;//如果點(diǎn)擊的當(dāng)前已選中則返回 checkboxArr.forEach(item => { item.checked = false }) checkboxArr[index].checked = true;//改變當(dāng)前選中的checked值 this.setData({ checkboxArr: checkboxArr }); }, radioChange: function (e) { var checkValue = e.detail.value; this.setData({ checkValue: checkValue }); }, confirm: function() {// 提交 console.log(this.data.checkValue)//所有選中的項(xiàng)的value }, })
最后上個(gè)效果截圖
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序 flexbox layout快速實(shí)現(xiàn)基本布局的解決方案
flexbox layout 彈性盒子布局。彈性盒子可以快速的對(duì)小程序進(jìn)行布局。這篇文章主要介紹了微信小程序 flexbox layout快速實(shí)現(xiàn)基本布局的方法,需要的朋友可以參考下2020-03-03JavaScript中調(diào)用函數(shù)的4種方式代碼實(shí)例
這篇文章主要介紹了JavaScript中調(diào)用函數(shù)的4種方式代碼實(shí)例,本文分別給出方法調(diào)用模式、函數(shù)調(diào)用模式、構(gòu)造器調(diào)用模式、apply調(diào)用模式4種方式的代碼實(shí)例,需要的朋友可以參考下2015-07-07全面了解構(gòu)造函數(shù)繼承關(guān)鍵apply call
下面小編就為大家?guī)?lái)一篇全面了解構(gòu)造函數(shù)繼承關(guān)鍵apply call。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07JS前端面試必備——基本排序算法原理與實(shí)現(xiàn)方法詳解【插入/選擇/歸并/冒泡/快速排序】
這篇文章主要介紹了JS前端面試基本排序算法原理與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了JS常見(jiàn)的基本排序算法相關(guān)原理、實(shí)現(xiàn)方法、時(shí)間復(fù)雜度及操作注意事項(xiàng),需要的朋友可以參考下2020-02-02Javascript無(wú)參數(shù)和有參數(shù)類繼承問(wèn)題解決方法
這篇文章主要介紹了Javascript無(wú)參數(shù)和有參數(shù)類繼承問(wèn)題解決方法,本文講解了無(wú)參數(shù)類繼承的問(wèn)題和有參類繼承的問(wèn)題,并給出了解決方案,需要的朋友可以參考下2015-03-03JavaScript 下載鏈接圖片后上傳的實(shí)現(xiàn)
這篇文章主要介紹了JavaScript 下載鏈接圖片后上傳的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03js綜合應(yīng)用實(shí)例簡(jiǎn)單的表格統(tǒng)計(jì)
在做調(diào)查問(wèn)卷的過(guò)程中,遇到一個(gè)表格的統(tǒng)計(jì)問(wèn)題,一個(gè)需要用到j(luò)s方面的綜合知識(shí),感覺(jué)還不錯(cuò)所以記錄下來(lái)與大家分享,感興趣的朋友可以了解下2013-09-09