小程序?qū)崿F(xiàn)多個按鈕toggle功能
百度上很多都是只設(shè)置一個按鈕的toggle,所以我現(xiàn)在來稍微總結(jié)下:多個按鈕如何實現(xiàn)自身的toggle功能。
原理:1,列表展示的時候,我們會用wx:for 來循環(huán)數(shù)據(jù),那么我們就會得到相應(yīng)的當(dāng)前的第幾個數(shù)據(jù)(即 wx:key="index")
2.在每一個數(shù)據(jù)里面添加一個toggle的屬性,toggle=false 則不展示,
3.設(shè)置一個點擊方法,獲取當(dāng)前按鈕所在的是第幾個數(shù)據(jù),然后將相應(yīng)的toggle取反,然后將修改后的數(shù)據(jù)重新寫進(jìn)去 (我出錯的地方就在這)
4. 在wxml頁面判斷toggle的值是true/false ,然后修改相應(yīng)的class名
js代碼:
-
Page({
-
data:{
-
datas:[]
-
},
-
onLoad:function(options){
-
var that=this;
-
API.my_ajax('',function(res){ //用mock.js 設(shè)置的模擬數(shù)據(jù)調(diào)用格式
-
// console.log(res);
-
var listData=res.data;
-
for(var i=0;i
-
listData[i]['toggle']=false; //添加toggle 屬性
-
}
-
that.setData({
-
datas:listData
-
})
-
// console.log(listData)
-
})
-
},
-
showBtn:function(e){
-
console.log(e);
-
console.log(this);
-
//這兩個console.log 可以查看當(dāng)前方法里面所有的數(shù)據(jù),可以查找一下我們所需要的內(nèi)容是否有在里面,底下的index 就是這樣找到的
-
var a=e.currentTarget.dataset.index;
-
var b=this.data.datas[a].toggle;
-
this.data.datas[a].toggle=!b;
-
//設(shè)置之后我們要把數(shù)據(jù)從新添回去
-
this.setData({
-
datas:this.data.datas
-
})
第二部分:如何開通一個小商店