亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue源碼學習之Object.defineProperty 對數組監聽

2019-11-19 13:45:20
字體:
來源:轉載
供稿:網友

上一篇中,我們介紹了一下defineProperty 對對象的監聽,這一篇我們看下defineProperty 對數組的監聽

數組的變化

先讓我們了解下Object.defineProperty()對數組變化的跟蹤情況:

var a={};bValue=1;Object.defineProperty(a,"b",{  set:function(value){    bValue=value;    console.log("setted");  },  get:function(){    return bValue;  }});a.b;//1a.b=[];//setteda.b=[1,2,3];//setteda.b[1]=10;//無輸出a.b.push(4);//無輸出a.b.length=5;//無輸出a.b;//[1,10,3,4,undefined];

可以看到,當a.b被設置為數組后,只要不是重新賦值一個新的數組對象,任何對數組內部的修改都不會觸發setter方法的執行。這一點非常重要,因為基于Object.defineProperty()方法的現代前端框架實現的數據雙向綁定也同樣無法識別這樣的數組變化。因此第一點,如果想要觸發數據雙向綁定,我們不要使用arr[1]=newValue;這樣的語句來實現;第二點,框架也提供了許多方法來實現數組的雙向綁定。

對于框架如何實現數組變化的監測,大多數情況下,框架會重寫Array.prototype.push方法,并生成一個新的數組賦值給數據,這樣數據雙向綁定就會觸發。

實現簡單的對數組的變化的監聽

var arrayPush = {};(function(method){  var original = Array.prototype[method];  arrayPush[method] = function() {    // this 指向可通過下面的測試看出    console.log(this);    return original.apply(this, arguments)  };})('push');var testPush = [];testPush.__proto__ = arrayPush;// 通過輸出,可以看出上面所述 this 指向的是 testPush// []testPush.push(1);// [1]testPush.push(2);

在官方文檔,所需監視的只有 push()、pop()、shift()、unshift()、splice()、sort()、reverse() 7 種方法。我們可以遍歷一下:

var arrayProto = Array.prototypevar arrayMethods = Object.create(arrayProto);[ 'push', 'pop', 'shift', 'unshift', 'splice', 'sort', 'reverse'].forEach(function(item){  Object.defineProperty(arrayMethods,item,{    value:function mutator(){      //緩存原生方法,之后調用      console.log('array被訪問');      var original = arrayProto[item]        var args = Array.from(arguments)    original.apply(this,args)      // console.log(this);    },  })})

完整代碼

function Observer(data){  this.data = data;  this.walk(data);}var p = Observer.prototype;var arrayProto = Array.prototypevar arrayMethods = Object.create(arrayProto);[ 'push', 'pop', 'shift', 'unshift', 'splice', 'sort', 'reverse'].forEach(function(item){  Object.defineProperty(arrayMethods,item,{    value:function mutator(){      //緩存原生方法,之后調用      console.log('array被訪問');      var original = arrayProto[item]        var args = Array.from(arguments)    original.apply(this,args)      // console.log(this);    },  })})p.walk = function(obj){  var value;  for(var key in obj){    // 通過 hasOwnProperty 過濾掉一個對象本身擁有的屬性     if(obj.hasOwnProperty(key)){      value = obj[key];      // 遞歸調用 循環所有對象出來      if(typeof value === 'object'){        if (Array.isArray(value)) {          var augment = value.__proto__ ? protoAugment : copyAugment           augment(value, arrayMethods, key)          observeArray(value)        }        new Observer(value);      }      this.convert(key, value);    }  }};p.convert = function(key, value){  Object.defineProperty(this.data, key, {    enumerable: true,    configurable: true,    get: function(){      console.log(key + '被訪問');      return value;    },    set: function(newVal){      console.log(key + '被修改,新' + key + '=' + newVal);      if(newVal === value) return ;      value = newVal;    }  })}; var data = {  user: {    // name: 'zhangsan',    age: function(){console.log(1)}  },  apg: [{'a': 'b'},2,3]}function observeArray (items) {  for (var i = 0, l = items.length; i < l; i++) {    observe(items[i])  }}//數據重復Observerfunction observe(value){  if(typeof(value) != 'object' ) return;  var ob = new Observer(value)   return ob;}//輔助方法function def (obj, key, val) { Object.defineProperty(obj, key, {  value: val,  enumerable: true,  writable: true,  configurable: true })}// 兼容不支持__proto__的方法//重新賦值Array的__proto__屬性function protoAugment (target,src) { target.__proto__ = src}//不支持__proto__的直接修改相關屬性方法function copyAugment (target, src, keys) { for (var i = 0, l = keys.length; i < l; i++) {  var key = keys[i]  def(target, key, src[key]) }}var app = new Observer(data);// data.apg[2] = 111;data.apg.push(5);// data.apg[0].a = 10;// console.log(data.apg);

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美电影在线观看完整版| 亚洲男人天天操| 日韩av在线网| 亚洲淫片在线视频| 国产精品电影观看| 国产精品精品久久久| 国产成人啪精品视频免费网| 精品亚洲一区二区| 国产成人精品999| 欧美日韩国产精品一区二区三区四区| 欧美日韩国产一区二区| 国产精品高潮呻吟久久av黑人| 亚洲天堂av在线免费| 久久精品国产精品| 精品国偷自产在线| 亚洲国产一区二区三区四区| 午夜精品久久久久久久99热浪潮| 国产精品入口日韩视频大尺度| 亚洲精品国产精品国产自| 久久国产精品久久久久久久久久| 国产精品av免费在线观看| 日韩成人在线观看| 欧美电影免费观看电视剧大全| 日韩精品在线观看视频| 国产精品久久久久久中文字| 色噜噜狠狠狠综合曰曰曰88av| 精品国产欧美一区二区三区成人| 亚洲欧美日韩第一区| 欧美孕妇与黑人孕交| 午夜精品福利在线观看| 欧美亚洲另类视频| 欧美另类极品videosbestfree| 亚洲一区二区免费在线| 亚洲日本中文字幕| 日韩亚洲成人av在线| 国产精品99久久久久久久久久久久| 精品国产福利视频| 在线播放日韩欧美| 亚洲精品在线观看www| 亚洲淫片在线视频| 欧美成人三级视频网站| 成人激情av在线| 日韩av免费在线| 日韩av影片在线观看| 欧美天天综合色影久久精品| 久久久99免费视频| 精品美女久久久久久免费| 久久久亚洲欧洲日产国码aⅴ| 美女av一区二区三区| 91精品视频观看| 亚洲最新中文字幕| 日韩国产欧美精品在线| 国产+人+亚洲| 在线不卡国产精品| 日本高清+成人网在线观看| 久久久精品国产亚洲| 精品久久久久久| 全色精品综合影院| 国产精品热视频| 久久精品在线视频| 国产精品扒开腿做爽爽爽的视频| 色婷婷久久一区二区| 欧美日韩国产123| 中文国产亚洲喷潮| 久久躁狠狠躁夜夜爽| 久久婷婷国产麻豆91天堂| 国产精品一区二区三区久久| 亚洲精选在线观看| 亚洲精美色品网站| 日韩欧美国产一区二区| 2019中文在线观看| www.亚洲成人| 亚洲tv在线观看| 欧美精品制服第一页| 欧美成人亚洲成人日韩成人| 中文字幕久热精品视频在线| 中文字幕亚洲欧美一区二区三区| 亚洲免费视频网站| 久久精品亚洲精品| 午夜精品www| 日韩中文av在线| 亚洲视频自拍偷拍| 最近2019免费中文字幕视频三| 日韩精品福利网站| 欧美激情一区二区三级高清视频| 国产精品免费一区| 欧美日韩国产影院| 日韩欧美在线中文字幕| 亚洲天堂日韩电影| 国模视频一区二区| 国产一区二区视频在线观看| 日韩欧美在线视频免费观看| 欧美激情中文字幕在线| 国产精品久久久久久久av大片| 6080yy精品一区二区三区| 国产精品扒开腿做爽爽爽的视频| 538国产精品一区二区在线| 成人国产精品久久久久久亚洲| 日韩中文字幕视频在线观看| 欧美一级淫片videoshd| 久久久免费电影| 另类少妇人与禽zozz0性伦| 在线观看日韩www视频免费| 国产精品白丝jk喷水视频一区| 久久久久一本一区二区青青蜜月| 国产精品一区二区av影院萌芽| 亚洲在线免费视频| 欧美激情亚洲激情| 欧美一性一乱一交一视频| 一区二区三区国产视频| 综合网日日天干夜夜久久| 亚洲成色999久久网站| 亚洲欧美中文另类| 亚洲人成电影网站色www| 亚洲性69xxxbbb| 亚洲另类激情图| 中文字幕精品一区二区精品| 国产亚洲欧洲高清一区| 欧美精品一区二区三区国产精品| 国产91免费看片| 91亚洲永久免费精品| 亚洲国产精品一区二区久| 精品久久久一区二区| 久久精品视频播放| 久久中文字幕一区| 亚洲精品视频中文字幕| 亚洲欧美成人精品| 久久久久久国产免费| 国产成人aa精品一区在线播放| 热久久免费视频精品| 欧美成人精品激情在线观看| 中文字幕日韩av电影| 91中文在线视频| 久久成人综合视频| 久久中文久久字幕| 78色国产精品| 国产一区二区黑人欧美xxxx| 亚洲精品在线看| 国a精品视频大全| 午夜精品一区二区三区av| 色婷婷成人综合| 成人精品一区二区三区电影黑人| 欧美在线精品免播放器视频| 欧美成人性色生活仑片| 国产精品一区二区久久| 国产精品稀缺呦系列在线| 亚洲自拍偷拍色图| 欧美视频在线观看免费| 亚洲精品日韩欧美| 日韩一二三在线视频播| 国产精品亚洲一区二区三区| 久久影院中文字幕| 欧美贵妇videos办公室| 精品久久国产精品| 亚洲一区二区在线| 国产精品私拍pans大尺度在线| 国产精品91免费在线| 国产精品91免费在线| 亚洲人成欧美中文字幕| 成人中心免费视频| 日韩黄色av网站| 欧洲午夜精品久久久| 国产91在线播放九色快色| 97视频免费在线看|