注冊(cè)登錄

小程序?qū)崿F(xiàn)多個(gè)按鈕toggle功能

2020-09-28
導(dǎo)讀: 百度上很多都是只設(shè)置一個(gè)按鈕的toggle,所以我現(xiàn)在來稍微總結(jié)下:多個(gè)按鈕如何實(shí)現(xiàn)自身的toggle功能。 原理:1,列表展示的時(shí)候,我們會(huì)用wx:...

百度上很多都是只設(shè)置一個(gè)按鈕的toggle,所以我現(xiàn)在來稍微總結(jié)下:多個(gè)按鈕如何實(shí)現(xiàn)自身的toggle功能。

原理:1,列表展示的時(shí)候,我們會(huì)用wx:for 來循環(huán)數(shù)據(jù),那么我們就會(huì)得到相應(yīng)的當(dāng)前的第幾個(gè)數(shù)據(jù)(即 wx:key="index")
2.在每一個(gè)數(shù)據(jù)里面添加一個(gè)toggle的屬性,toggle=false 則不展示,
3.設(shè)置一個(gè)點(diǎn)擊方法,獲取當(dāng)前按鈕所在的是第幾個(gè)數(shù)據(jù),然后將相應(yīng)的toggle取反,然后將修改后的數(shù)據(jù)重新寫進(jìn)去 (我出錯(cuò)的地方就在這)
4. 在wxml頁面判斷toggle的值是true/false ,然后修改相應(yīng)的class名
js代碼:

小程序?qū)崿F(xiàn)多個(gè)按鈕toggle功能


  1. Page({
  2. data:{
  3. datas:[]
  4. },
  5. onLoad:function(options){
  6. var that=this;
  7. API.my_ajax('',function(res){ //用mock.js 設(shè)置的模擬數(shù)據(jù)調(diào)用格式
  8. // console.log(res);
  9. var listData=res.data;
  10. for(var i=0;i
  11. listData[i]['toggle']=false; //添加toggle 屬性
  12. }
  13. that.setData({
  14. datas:listData
  15. })
  16. // console.log(listData)
  17. })
  18. },
  19. showBtn:function(e){
  20. console.log(e);
  21. console.log(this);
  22. //這兩個(gè)console.log 可以查看當(dāng)前方法里面所有的數(shù)據(jù),可以查找一下我們所需要的內(nèi)容是否有在里面,底下的index 就是這樣找到的
  23.  
  24. var a=e.currentTarget.dataset.index;
  25. var b=this.data.datas[a].toggle;
  26. this.data.datas[a].toggle=!b;
  27.  
  28. //設(shè)置之后我們要把數(shù)據(jù)從新添回去
  29. this.setData({
  30. datas:this.data.datas
  31. })
重磅推薦:小程序開店目錄

第一部分:小商店是什么

第二部分:如何開通一個(gè)小商店

第三部分:如何登錄小商店

第四部分:開店任務(wù)常見問題

第五部分:小商店可以賣什么

第六部分:HiShop小程序特色功能

第七部分:小程序直播

第八部分:小程序收貨/物流

第九部分:小程序怎么結(jié)算

第十部分:小程序客服

第十一部分:電商創(chuàng)業(yè)

第十二部分:小程序游戲開發(fā)

電話咨詢 微信咨詢 預(yù)約演示 0元開店