小程序?qū)崿F(xiàn)單選多選功能
小程序的單選組件radio和多選組件checkbox的樣式只提供更改顏色,這對實際項目中的需求顯然是不夠的,所以自己模擬實現(xiàn)一個。
踩坑點:小程序不支持操作dom
1、模擬實現(xiàn)多選框:
實現(xiàn)思路:思路非常簡單,給每個選項綁定checked屬性,類型為布爾值,點擊取反即可
<!--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: '選項A',
checked: false
}, {
name: '選項B',
checked: false
}, {
name: '選項C',
checked: false
}, {
name: '選項D',
checked: false
}, {
name: '選項E',
checked: false
}, {
name: '選項F',
checked: false
}],
},
checkbox: function (e) {
var index = e.currentTarget.dataset.index;//獲取當(dāng)前點擊的下標
var checkboxArr = this.data.checkboxArr;//選項集合
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)//所有選中的項的value
},
})
2、模擬實現(xiàn)單選框
思路:這個和多選差不多,區(qū)別就是需要在點擊時清空其他項的選中狀態(tài),然后再把當(dāng)前項設(shè)置為選中狀態(tài)
代碼也差不多
wxml的話就把check-group標簽改為radio-group; js那邊就在點擊時多加個判斷
<!--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: '選項A',
checked: false
}, {
name: '選項B',
checked: false
}, {
name: '選項C',
checked: false
}, {
name: '選項D',
checked: false
}, {
name: '選項E',
checked: false
}, {
name: '選項F',
checked: false
}],
},
radio: function (e) {
var index = e.currentTarget.dataset.index;//獲取當(dāng)前點擊的下標
var checkboxArr = this.data.checkboxArr;//選項集合
if (checkboxArr[index].checked) return;//如果點擊的當(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)//所有選中的項的value
},
})
最后上個效果截圖

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序 flexbox layout快速實現(xiàn)基本布局的解決方案
flexbox layout 彈性盒子布局。彈性盒子可以快速的對小程序進行布局。這篇文章主要介紹了微信小程序 flexbox layout快速實現(xiàn)基本布局的方法,需要的朋友可以參考下2020-03-03
JavaScript中調(diào)用函數(shù)的4種方式代碼實例
這篇文章主要介紹了JavaScript中調(diào)用函數(shù)的4種方式代碼實例,本文分別給出方法調(diào)用模式、函數(shù)調(diào)用模式、構(gòu)造器調(diào)用模式、apply調(diào)用模式4種方式的代碼實例,需要的朋友可以參考下2015-07-07
全面了解構(gòu)造函數(shù)繼承關(guān)鍵apply call
下面小編就為大家?guī)硪黄媪私鈽?gòu)造函數(shù)繼承關(guān)鍵apply call。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07
JS前端面試必備——基本排序算法原理與實現(xiàn)方法詳解【插入/選擇/歸并/冒泡/快速排序】
這篇文章主要介紹了JS前端面試基本排序算法原理與實現(xiàn)方法,結(jié)合實例形式詳細分析了JS常見的基本排序算法相關(guān)原理、實現(xiàn)方法、時間復(fù)雜度及操作注意事項,需要的朋友可以參考下2020-02-02
Javascript無參數(shù)和有參數(shù)類繼承問題解決方法
這篇文章主要介紹了Javascript無參數(shù)和有參數(shù)類繼承問題解決方法,本文講解了無參數(shù)類繼承的問題和有參類繼承的問題,并給出了解決方案,需要的朋友可以參考下2015-03-03

