最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
vue實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的函數(shù)Object.defineProperty-創(chuàng)新互聯(lián)

這篇文章主要介紹了vue實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的函數(shù)Object.defineProperty,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)專注于肥鄉(xiāng)企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè),成都做商城網(wǎng)站。肥鄉(xiāng)網(wǎng)站建設(shè)公司,為肥鄉(xiāng)等地區(qū)提供建站服務(wù)。全流程專業(yè)公司,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

Vue的優(yōu)點(diǎn)

Vue具體輕量級(jí)框架、簡(jiǎn)單易學(xué)、雙向數(shù)據(jù)綁定、組件化、數(shù)據(jù)和結(jié)構(gòu)的分離、虛擬DOM、運(yùn)行速度快等優(yōu)勢(shì),Vue中頁(yè)面使用的是局部刷新,不用每次跳轉(zhuǎn)頁(yè)面都要請(qǐng)求所有數(shù)據(jù)和dom,可以大大提升訪問速度和用戶體驗(yàn)。

在 ES5中新增了不少新的API, 例如  新增了 Object.xxx相關(guān)的方法,其中有一個(gè)定義屬性相關(guān)的 Object.defineProperty 這個(gè)方法(還有Object.defineProperties)這個(gè)方法是 vue框架實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的核心方法,它的定義如下:

Object.defineProperty([Object] obj, [String] propname, [Object] desp )

  1. @param  obj  要配置屬性的某個(gè)對(duì)象

  2. @param propname 要配置的屬性名,是一個(gè)字符串

  3. @param desp 對(duì)屬性的描述,是一個(gè)對(duì)象,

desp 中可以配置的項(xiàng)目 

<1> writable:  true/false 是否可寫

<2> configurable : true/false 是否可以配置,例如刪除該屬性

<3> enumerable: true/false 指的是是否可以使用 for in循環(huán)遍歷屬性

<4> value:  值  ,屬性的值

我們?cè)趯憊ue項(xiàng)目的時(shí)候會(huì)在 data屬性中添加我們自己的屬性,這個(gè)屬性在vue中是響應(yīng)式的,也就是它可以監(jiān)聽到數(shù)據(jù)的變化,做出相應(yīng)的改變(例如DOM操作)

我們自己利用 defineProperty給屬性生成setter和getter(也就是其他編程語(yǔ)言里的存取器),就可以達(dá)到監(jiān)聽數(shù)據(jù)變化的目的

下面我們來自己實(shí)現(xiàn)一個(gè)數(shù)據(jù)監(jiān)聽的小 demo

有如下的數(shù)據(jù)

  let vue = {
   data: {
    title: 'life style',
    content: 'bike walk sleep...'
   }
  };

已經(jīng)提前聲明的 data屬性及其內(nèi)部的屬性,我們的目標(biāo)是監(jiān)聽 data中,title和content的變化

如何做到呢? 屬性的個(gè)數(shù)是不確定的,所以我們可以使用 for in循環(huán)遍歷data對(duì)象的所有的屬性

  //如何監(jiān)聽用戶自定義的 data中屬性的改變?
  let data = vue.data;
  for (let prop in data) {
   data['__' + prop] = data[prop]; //存儲(chǔ)私有屬性
   Object.defineProperty(data, prop, {
    enumerable : true,
    set: function (newVal) {
     console.log('你正在修改'+prop + ' !...操作DOM...');
     // 數(shù)據(jù)校驗(yàn)
     this['__' + prop] = newVal;
    },
    get: function () {
     console.log('getter 獲取值 ...');
     return this['__' + prop];
    }
   });
  }

遍歷data屬性的時(shí)候調(diào)用 defineProperty來給data對(duì)象的屬性添加set和get方法,

我們給data添加一個(gè)新的屬性   __xxx來保存我們之前的值,以便在 get方法中獲取原來的值

set方法 用于監(jiān)聽這個(gè)屬性被重新賦值,

get方法用于獲取你想要的格式的值

此處需要注意的是 不要在 set和get中 使用this賦值或者取值,這樣會(huì)導(dǎo)致循環(huán)調(diào)用,出現(xiàn)問題!!!

另外 我們不要使用 var,而要使用 let ,因?yàn)関ar不是塊作用域, 會(huì)導(dǎo)致你最后訪問到的prop總是最后一個(gè)

定義好之后,我們可以修改 data中title和content屬性了,

當(dāng)我們給 title賦值的時(shí)候回自動(dòng)調(diào)用 set, 獲取值得時(shí)候自動(dòng)調(diào)用get

測(cè)試代碼

  // 賦值操作會(huì)調(diào)用這個(gè)屬性的set方法, 類似于 set('aaa')
  data.title = 'aaa';
  // 獲取值操作會(huì)調(diào)用這個(gè)屬性的get方法
  console.log(data.title);
  data.content = 123;
  // 此種動(dòng)態(tài)屬性方式也會(huì)觸發(fā) set / get
  data['title'] = 123;
  console.log(data['title']);

結(jié)果(建議在最新版的chrome中操作):

vue實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的函數(shù)Object.defineProperty

對(duì)剛剛的遍歷方法還存在一些問題和說明:

1.data屬性的某個(gè)屬性可能還是對(duì)象,也就是存在多層級(jí)對(duì)象監(jiān)聽的問題

此時(shí)可以使用遞歸函數(shù)遍歷data的屬性,進(jìn)行相同操作

2. 通過  data.title = 1是實(shí)際上是調(diào)用了 set方法, 這個(gè)類似于 OC中的點(diǎn)語(yǔ)法

3. 要同時(shí)定義多個(gè)屬性,可以使用

Object.defineProperties([Object] obj, [Object] props);

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“vue實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的函數(shù)Object.defineProperty”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)建站,關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

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


本文標(biāo)題:vue實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽的函數(shù)Object.defineProperty-創(chuàng)新互聯(lián)
標(biāo)題來源:http://fisionsoft.com.cn/article/dhiehe.html