小程序?qū)崿F(xiàn)單選多選功能
小程序的單選組件radio和多選組件checkbox的樣式只提供更改顏色,這對實(shí)際項(xiàng)目中的需求顯然是不夠的,所以自己模擬實(shí)現(xiàn)一個。
踩坑點(diǎn):小程序不支持操作dom
1、模擬實(shí)現(xiàn)多選框:
實(shí)現(xiàn)思路:思路非常簡單,給每個選項(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)單選框
思路:這個和多選差不多,區(qū)別就是需要在點(diǎn)擊時清空其他項(xiàng)的選中狀態(tài),然后再把當(dāng)前項(xiàng)設(shè)置為選中狀態(tài)
代碼也差不多
wxml的話就把check-group標(biāo)簽改為radio-group; js那邊就在點(diǎn)擊時多加個判斷
<!--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
},
})
最后上個效果截圖

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript字符串轉(zhuǎn)數(shù)字的多種方法總結(jié)
在 JavaScript 開發(fā)中,我們經(jīng)常需要將字符串轉(zhuǎn)換為數(shù)字,例如從輸入框獲取用戶輸入后進(jìn)行數(shù)學(xué)計(jì)算,JavaScript 提供了多種方法來實(shí)現(xiàn)這一功能,如 parseInt、parseFloat、Number 等,本文將詳細(xì)介紹這些方法的使用方式、適用場景以及可能的坑,需要的朋友可以參考下2025-03-03
微信小程序開發(fā)之好友列表字母列表跳轉(zhuǎn)對應(yīng)位置
這篇文章主要介紹了微信小程序開發(fā)之好友列表字母列表跳轉(zhuǎn)對應(yīng)位置的相關(guān)資料,希望通過本文能幫助到大家讓大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-09-09
微信小程序使用webview頁面轉(zhuǎn)pdf文件代碼示例
工作需求,將webview的內(nèi)容導(dǎo)出到pdf輸出,下面這篇文章主要給大家介紹了關(guān)于微信小程序使用webview頁面轉(zhuǎn)pdf文件的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-09-09
Textbox控件注冊回車事件及觸發(fā)按鈕提交事件具體實(shí)現(xiàn)
Lyncplus客戶端中訪問Web頁面時遇到了TextBox控件回車自動完成按鈕的提交事件失效的情況,于是上網(wǎng)查找相關(guān)的介紹最終解決了這兩個問題,感興趣的你可以參考下或許對你有所幫助2013-03-03

