91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序 setData 對 data數據影響問題

發布時間:2020-09-05 19:49:43 來源:腳本之家 閱讀:316 作者:千山冷易水寒 欄目:web開發

我是純前端的,有些時候沒有后端接口,只能模擬一些數據來操作。偶然之下,發現了setdata 的一些機制,也有可能不對,請多指教。

先放結論:data的變量通過setdata綁在一起,是同步變化的

準備做一個一鍵還原界面的按鈕事件,如果有后端接口,只需調一下接口,就可以了。問題是沒有,于是想弄兩個一模一樣的數組A,B;A用來渲染界面,一鍵還原的時候,就把B的值賦給A,從而引起頁面重新渲染,達到重置界面的效果。

結果一點反應也沒有。

data里有模擬的數組  itemleft  itemright,二選一,

定義代碼是這么寫的

this.setData({
  uniqueitem: (id == 'unfinish') ? this.data.itemleft[index] : this.data.itemright[index],
  cloneitem: (id == 'unfinish') ? this.data.itemleft[index] : this.data.itemright[index],
  baninput: (id == 'unfinish')?false:true
})

這是一鍵還原的代碼

this.setData({
  uniqueitem:this.data.cloneitem
})

后來通過console.log發現   uniqueitem、cloneitem和this.data.itemleft[index] 的值是一模一樣的,意思是,當我改變uniqueitem的時候,其他兩個都會跟著變。

然后,我把cloneitem的值通過緩存還獲取,代碼變成了這樣

this.setData({
  uniqueitem: (id == 'unfinish') ? this.data.itemleft[index] : this.data.itemright[index],
  baninput: (id == 'unfinish')?false:true
})
var that=this
wx.getStorage({
  key: 'item',
  success: function(res) {
    console.log(res)
    that.setData({
      cloneitem:res.data
    })
  },
})
this.setData({
  uniqueitem:this.data.cloneitem
})

改成這樣之后,一鍵還原第一次正常,后面再點全不正常

這是測試的console順序

console.log(this.data.itemleft[0])
console.log(this.data.uniqueitem)
console.log(this.data.cloneitem)

事先說明,改變date,改的是2的date

我通過一個函數改變了date,加1,

可以看到 1和2同時改變,3不變;

一鍵還原第一次

可以看到,1不變,3的值賦給了2;到目前正常

再次改變date,

可以看到,2和3一起變,1不變了

一鍵還原

和上面一樣不變了

后來我改成

var aaa = this.data.cloneitem;
this.setData({
  uniqueitem:aaa
})

效果和上面一樣。

結論,

當data有3個變量,a和b、c

this.setData({
  a:this.data.b
  c:this.data.b
})

意思是,a和b綁一起,c和b綁一起,3個一起變,改變一個等于改變3個。個人猜測,應該是存放變量a,b,c 的地址變成一個了。

this.setData({
  a:this.data.b
})

a和b一起變。

this.setData({
  a:this.data.c
})

a不和b一起變,和c一起變。

簡而言之,data的變量通過setdata綁在一起,是同步變化的,要小心。

總結

以上所述是小編給大家介紹的微信小程序 setData 對 data數據影響問題,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

彝良县| 六安市| 岳阳市| 博罗县| 南木林县| 湖南省| 来安县| 莱西市| 大同县| 湘西| 岑溪市| 油尖旺区| 丽水市| 乐昌市| 栾城县| 凉山| 太湖县| 叶城县| 曲沃县| 翼城县| 通榆县| 资阳市| 建始县| 淅川县| 衢州市| 青田县| 黔东| 都匀市| 武宁县| 句容市| 碌曲县| 青神县| 射阳县| 高邑县| 灵山县| 兴和县| 年辖:市辖区| 铁岭县| 随州市| 临猗县| 庆云县|