怎么在小程序中實(shí)現(xiàn)單選多選功能

怎么在小程序中實(shí)現(xiàn)單選多選功能?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

在東海等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供做網(wǎng)站、成都網(wǎng)站設(shè)計(jì) 網(wǎng)站設(shè)計(jì)制作按需網(wǎng)站建設(shè),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),營(yíng)銷型網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè),東海網(wǎng)站建設(shè)費(fèi)用合理。

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
 },
})

看完上述內(nèi)容,你們掌握怎么在小程序中實(shí)現(xiàn)單選多選功能的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

網(wǎng)頁(yè)標(biāo)題:怎么在小程序中實(shí)現(xiàn)單選多選功能
URL鏈接:http://muchs.cn/article42/pdhsec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈服務(wù)器托管、定制網(wǎng)站、微信小程序網(wǎng)站改版、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)