亚洲AVI,黑人巨茎大战欧美白妇,初高中生洗澡自慰高清网站,欧美日韩无砖专区一中文字

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設、域名注冊、服務器等服務

Vue源碼之數(shù)據(jù)代理訪問的示例分析-創(chuàng)新互聯(lián)

小編給大家分享一下Vue源碼之數(shù)據(jù)代理訪問的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)基于成都重慶香港及美國等地區(qū)分布式IDC機房數(shù)據(jù)中心構建的電信大帶寬,聯(lián)通大帶寬,移動大帶寬,多線BGP大帶寬租用,是為眾多客戶提供專業(yè)服務器托管報價,主機托管價格性價比高,為金融證券行業(yè)服務器托管,ai人工智能服務器托管提供bgp線路100M獨享,G口帶寬及機柜租用的專業(yè)成都idc公司。

概念解析:

1) 數(shù)據(jù)代理: 通過一個對象代理對另一個對象(在前一個對象內部)中屬性的操作(讀/寫)
2) vue 數(shù)據(jù)代理: 通過 vm 對象(即this)來代理 data 對象中所有屬性的操作
3) 好處: 更方便的操作 data 中的數(shù)據(jù)
4) 基本實現(xiàn)流程
a. 通過 Object.defineProperty()給 vm 添加與 data 對象的屬性對應的屬性描述符
b. 所有添加的屬性都包含 getter/setter
c. getter/setter 內部去操作 data 中對應的屬性數(shù)據(jù)

疑問

不知道你在使用Vue的時候有沒有想過,為什么定義在 data 對象中的屬性,可以用 Vue 的實例 this 進行訪問?

我們來看看源碼的實現(xiàn)。

var sharedPropertyDefinition = {
 enumerable: true,
 configurable: true,
 get: noop,
 set: noop
};

// 源碼中是這樣調用的:proxy(vm, '_data', key)
// vm是Vue的實例,key是data對象屬性的名字
function proxy (target, sourceKey, key) {
 sharedPropertyDefinition.get = function proxyGetter () {
  return this[sourceKey][key]
 };
 sharedPropertyDefinition.set = function proxySetter (val) {
  this[sourceKey][key] = val;
 };
 Object.defineProperty(target, key, sharedPropertyDefinition);
}

比如有個如下demo

const vm = new Vue({
  el: '#app',
  data: { message: 'Hello Vue!' },
  created() {
    console.log(this.message)      // 輸出Hello Vue!
    console.log(this._data.message)   // 同樣輸出Hello Vue!
  }
})

也就是說當我們這樣 this.message 寫的時候, Vue 通過 Object.defineProperty 給 this.message 設置一層代理,實際訪問的是 this._data 里的 message 屬性,而 this._data 指向的對象就是我們寫的 data 對象。

以上是“Vue源碼之數(shù)據(jù)代理訪問的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)成都網(wǎng)站設計公司行業(yè)資訊頻道!

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


本文題目:Vue源碼之數(shù)據(jù)代理訪問的示例分析-創(chuàng)新互聯(lián)
網(wǎng)站地址:http://news.spvevtbd.cn/article/gesds.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP