微信小程序中this.data與this.setData的區(qū)別詳解
一、摘要
小程序中我們會(huì)經(jīng)常使用到this.data與this.setData。其中this.data是用來獲取頁面data對(duì)象的,而this.setData是用來更新界面的。那么他們之間的區(qū)別與聯(lián)系你真的搞懂了嗎?
Page.prototype.setData()
setData 函數(shù)用于將數(shù)據(jù)從邏輯層發(fā)送到視圖層,同時(shí)改變對(duì)應(yīng)的 this.data 的值。
注意:
- 直接修改 this.data 無效,無法改變頁面的狀態(tài),還會(huì)造成數(shù)據(jù)不一致。
- 單次設(shè)置的數(shù)據(jù)不能超過1024kB,請(qǐng)盡量避免一次設(shè)置過多的數(shù)據(jù)。
二、正文
this.data可以獲取頁面data對(duì)象,但是它返回的對(duì)象到底是新的對(duì)象還是僅僅只是一個(gè)引用吶。這個(gè)很關(guān)鍵,在日常開發(fā)中很可能因?yàn)椴恢阑蛘呤亲约旱氖韬鰧?dǎo)致bug,而且很難排查原因。帶著這個(gè)疑問我們來做一下試驗(yàn)。由于時(shí)間比較緊,博主就不單獨(dú)寫demo了,項(xiàng)目中可能有大量其它代碼干擾我們分析,還請(qǐng)見諒。
var data = this.data.swiperItems[currentSwiper];
這行代碼使用this.data獲取了我需要的對(duì)象,并且賦值給data變量,下面分別打印data和this.data的相應(yīng)對(duì)象。

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

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

跟我們預(yù)想的一樣,即使我先賦值后加字段,data得出的結(jié)果也是被修改了的。
可能有人會(huì)問,那為啥用使用this.setData后才能看到界面的變換呢?至于this.setData我們可以看成是更新界面,并且貌似this.setData里面又托管了一個(gè)this.data的副本。因?yàn)樵谖腋淖僼his.data后立馬去執(zhí)行
this.setData({});
界面并不會(huì)更新,這就說明我們需要更新this.setData管理的那個(gè)數(shù)據(jù)對(duì)象才能更新界面,而界面真正加載的數(shù)據(jù)也是來自那里。想要知道具體怎么實(shí)現(xiàn)的,那就要去看源代碼了。
三、結(jié)論
總結(jié)一下就是:this.data與this.setData的關(guān)系就是this.setData里面存儲(chǔ)的是this.data的副本,而界面是從this.setData里面托管的this.data的副本取數(shù)據(jù)的。所以我們更改this.data并不會(huì)直接更新界面,因?yàn)檫@個(gè)時(shí)候的this.setData里面的副本還是沒有更新前的。
好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
JS+JSP通過img標(biāo)簽調(diào)用實(shí)現(xiàn)靜態(tài)頁面訪問次數(shù)統(tǒng)計(jì)的方法
這篇文章主要介紹了JS+JSP通過img標(biāo)簽調(diào)用實(shí)現(xiàn)靜態(tài)頁面訪問次數(shù)統(tǒng)計(jì)的方法,基于JavaScript動(dòng)態(tài)調(diào)用jsp頁面通過對(duì)TXT文本文件的讀寫實(shí)現(xiàn)統(tǒng)計(jì)訪問次數(shù)的功能,需要的朋友可以參考下2015-12-12
javascript數(shù)字格式化通用類 accounting.js使用
accounting.js 是一個(gè)非常小的JavaScript方法庫(kù)用于對(duì)數(shù)字,金額和貨幣進(jìn)行格式化。并提供可選的Excel風(fēng)格列渲染。它沒有依賴任何JS框架。貨幣符號(hào)等可以按需求進(jìn)行定制2012-08-08
JavaScript?TWaver使用中間點(diǎn)畫折線的方法
這篇文章主要介紹了JavaScript?TWaver使用中間點(diǎn)畫折線的方法,TWaver的圖形組件庫(kù)中提供了拓?fù)浣M件、地圖組件、設(shè)備圖組件,以及表格、樹圖、屬性表、圖表等豐富的通用圖形界面組件2022-07-07
JavaScript實(shí)現(xiàn)單點(diǎn)登錄的示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)單點(diǎn)登錄的示例,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下2020-09-09
微信小程序批量監(jiān)聽輸入框?qū)Π粹o樣式進(jìn)行控制的實(shí)現(xiàn)代碼
這篇文章主要介紹了小程序批量監(jiān)聽輸入框?qū)Π粹o樣式進(jìn)行控制的實(shí)現(xiàn)代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10
JavaScript實(shí)現(xiàn)帶并發(fā)限制的異步調(diào)度器
這篇文章主要為大家詳細(xì)介紹了如何基于JS實(shí)現(xiàn)一個(gè)帶并發(fā)限制的異步調(diào)度器?Scheduler,保證同時(shí)運(yùn)行的任務(wù)最多有N個(gè),感興趣的小伙伴可以了解下2024-03-03
layui: layer.open加載窗體時(shí)出現(xiàn)遮罩層的解決方法
今天小編就為大家分享一篇layui: layer.open加載窗體時(shí)出現(xiàn)遮罩層的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-09-09

