国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 22:07:41
文檔

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

微信小程序中this.data與this.setData的區(qū)別詳解:一、摘要 小程序中我們會經(jīng)常使用到this.data與this.setData。其中this.data是用來獲取頁面data對象的,而this.setData是用來更新界面的。那么他們之間的區(qū)別與聯(lián)系你真的搞懂了嗎? Page.prototype.setData() setData 函數(shù)用于將
推薦度:
導(dǎo)讀微信小程序中this.data與this.setData的區(qū)別詳解:一、摘要 小程序中我們會經(jīng)常使用到this.data與this.setData。其中this.data是用來獲取頁面data對象的,而this.setData是用來更新界面的。那么他們之間的區(qū)別與聯(lián)系你真的搞懂了嗎? Page.prototype.setData() setData 函數(shù)用于將

一、摘要

小程序中我們會經(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里面的副本還是沒有更新前的。

    好了,

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

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

    微信小程序中this.data與this.setData的區(qū)別詳解:一、摘要 小程序中我們會經(jīng)常使用到this.data與this.setData。其中this.data是用來獲取頁面data對象的,而this.setData是用來更新界面的。那么他們之間的區(qū)別與聯(lián)系你真的搞懂了嗎? Page.prototype.setData() setData 函數(shù)用于將
    推薦度:
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 另类激情亚洲 | 久久久精品国产 | 亚洲国产日韩在线精品频道 | 国产精品123| 999成人精品视频在线 | 亚洲精品乱码久久久久久v 亚洲精品免费观看 | 欧美视频一区二区三区 | 亚洲综合精品一区二区三区中文 | 日本五十路视频 | 91久久综合九色综合欧美98 | 亚洲成人免费 | 欧美国产日韩在线播放 | 国产欧美久久一区二区 | 国产在线视频网 | 国产一区二区三区免费在线视频 | 中文字幕另类 | 美国一级大黄大色毛片视频一 | 国产精品日韩 | 99国产精品久久久久久久... | 亚洲va欧美| 亚洲专区路线一路线二天美 | 91精品国产品国语在线不卡 | 久久精品国产精品亚洲综合 | 亚洲一区二区三区四 | 全免费午夜一级毛片一级毛 | 香港黄色| 国产va在线观看 | 日本一区二区三区免费观看 | 欧美日韩一区二区三区在线 | 日韩国产综合 | 亚洲欧美日韩国产综合高清 | 日韩a无v码在线播放免费 | 欧美性一区二区三区五区 | 综合伊人久久在一二三区 | 亚洲欧美国产精品 | 丝袜国产一区 | 国内一区二区三区精品视频 | 亚洲伊人色| 明星国产欧美日韩在线观看 | 久久99精品久久久久久噜噜 | 亚洲综合另类 |