欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2018年09月17日 09:01:26   作者:CODE_XIA  
這篇文章主要給大家介紹了關(guān)于微信小程序中this.data與this.setData區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧

一、摘要

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

Page.prototype.setData()

setData 函數(shù)用于將數(shù)據(jù)從邏輯層發(fā)送到視圖層,同時改變對應(yīng)的 this.data 的值。

注意:

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

二、正文

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

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

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

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

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

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

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

 this.setData({});

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

三、結(jié)論

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

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論