麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 課堂 > 小程序 > 正文

微信小程序中this.data與this.setData的區別詳解

2020-03-21 16:10:36
字體:
來源:轉載
供稿:網友

一、摘要

小程序中我們會經常使用到this.data與this.setData。其中this.data是用來獲取頁面data對象的,而this.setData是用來更新界面的。那么他們之間的區別與聯系你真的搞懂了嗎?

Page.prototype.setData()

setData 函數用于將數據從邏輯層發送到視圖層,同時改變對應的 this.data 的值。

注意:

  • 直接修改 this.data 無效,無法改變頁面的狀態,還會造成數據不一致。
  • 單次設置的數據不能超過1024kB,請盡量避免一次設置過多的數據。

二、正文

this.data可以獲取頁面data對象,但是它返回的對象到底是新的對象還是僅僅只是一個引用吶。這個很關鍵,在日常開發中很可能因為不知道或者是自己的疏忽導致bug,而且很難排查原因。帶著這個疑問我們來做一下試驗。由于時間比較緊,博主就不單獨寫demo了,項目中可能有大量其它代碼干擾我們分析,還請見諒。

 var data = this.data.swiperItems[currentSwiper];

這行代碼使用this.data獲取了我需要的對象,并且賦值給data變量,下面分別打印data和this.data的相應對象。

微信小程序,this.data,this.setData

可以看到這兩個對象的內容是一致的。下面我將在data變量中添加一個test字段,然后再看這兩者的打印結果。注意我并不會對this.data操作。

微信小程序,this.data,this.setData

可以看到他們都發生了變換,所以這是淺拷貝,也就是兩個變量指向了同一片存儲區域,無論通過哪個變量操作這片存儲區域,相應的兩個變量得出的值都會變換。為了繼續證明我們的猜想是正確的,下面我只操作this.data而不操作data。

微信小程序,this.data,this.setData

跟我們預想的一樣,即使我先賦值后加字段,data得出的結果也是被修改了的。

可能有人會問,那為啥用使用this.setData后才能看到界面的變換呢?至于this.setData我們可以看成是更新界面,并且貌似this.setData里面又托管了一個this.data的副本。因為在我改變this.data后立馬去執行

 this.setData({});

界面并不會更新,這就說明我們需要更新this.setData管理的那個數據對象才能更新界面,而界面真正加載的數據也是來自那里。想要知道具體怎么實現的,那就要去看源代碼了。

三、結論

總結一下就是:this.data與this.setData的關系就是this.setData里面存儲的是this.data的副本,而界面是從this.setData里面托管的this.data的副本取數據的。所以我們更改this.data并不會直接更新界面,因為這個時候的this.setData里面的副本還是沒有更新前的。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩视频精品一区 | 麻豆蜜桃在线观看 | 色综合欧美 | 91精品免费观看 | 久久国产精品久久久久久电车 | 亚洲电影免费观看国语版 | 欧美成人一区二区视频 | 国产黄色毛片 | 久久久久久久一区二区三区 | 羞羞的视频在线观看 | 成年人毛片视频 | 91精品国产日韩91久久久久久360 | 91美女视频在线观看 | 欧美性生活区 | 国产精品视频一区二区三区综合 | 免费毛片电影 | 日日草夜夜草 | 主播粉嫩国产在线精品 | 全黄性性激高免费视频 | 9797色| 中国杭州少妇xxxx做受 | lutube成人福利在线观看污 | 在线观看免费毛片视频 | 国内自拍网址 | 欧美亚洲一区二区三区四区 | 精品国产一区二区三区久久久 | 中文字幕极速在线观看 | 日韩视频精品一区 | 哪里可以看免费的av | 精品国产一区二区三区四 | 91久久精品一 | 一级免费黄色免费片 | 久久久亚洲欧美综合 | 日本成人一二三区 | 一级一级一级一级毛片 | 国产精品久久久久久久久久东京 | av懂色| tube7xxx| 把娇妻调教成暴露狂 | 亚洲午夜精品视频 | 一级裸体视频 |