亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

vue雙向綁定問題

vue雙向綁定問題

翻過高山走不出你 2019-03-18 21:02:34
1.初始化 vue時,會通過數據劫持 給data中的每個屬性設置get和set方法2.每個get中通過dep.depend()將當前的watch添加到subs搜集器中3.設置新值時,觸發set中的dep.notify()去通知 watch.update更新 視圖現在疑問1.data中的每個屬性觸發set,怎么知道當前屬性跟哪個 dep對應綁定的呢?我看網上說是通過閉包,這樣的話,data中變量過多,會不會產生性能問題2.初始化vue實例時,Dep.taget的當前watch,是什么時候入棧的,我看watch里的get方法頂部pushTarget入棧,后方法結束前又popTarget了### 問題描述
查看完整描述

2 回答

?
慕田峪7331174

TA貢獻1828條經驗 獲得超13個贊

每個屬性都會對應一個dep,在觸發get函數時入棧

查看完整回答
反對 回復 2019-03-18
?
哆啦的時光機

TA貢獻1779條經驗 獲得超6個贊

可以再網上找一些簡單的實現:

function?observer(obj)?{????if?(!obj?||?typeof?obj?!==?'object')?{????????return?;
????}????Object.keys(obj).forEach((key)?=>?{
????????reactive(obj,?key,?obj[key]);
????});
}function?reactive(obj,?key,?value)?{
????observer(value);????const?dep?=?new?Dep();????Object.defineProperty(obj,?key,?{????????configurable:?false,????????enumerable:?true,
????????get()?{
????????????Dep.target?&&?dep.addSub(Dep.target);????????????return?value;
????????},
????????set(newValue)?{
????????????value?=?newValue;
????????????dep.notify();
????????}
????})
}class?Dep{????constructor()?{????????this.subs?=?[];
????}
????addSub(sub)?{????????this.subs.push(sub);
????}
????notify()?{????????this.subs.forEach(sub?=>?{
????????????sub.update();
????????});
????}
}class?Watcher{????constructor(vm,?exp,?cb){????????this.vm?=?vm;????????this.exp?=?exp;????????this.cb?=?cb;????????this.value?=?this.get();
????}
????get()?{
????????Dep.target?=?this;????????const?value?=?this.vm[this.exp];
????????Dep.target?=?null;????????return?value;
????}
????update()?{????????const?oldValue?=?this.value;????????const?value?=?this.get();????????if?(oldValue?!==?value){????????????this.value?=?value;????????????this.cb.call(this.vm,?value,?oldValue);
????????}
????}
}


查看完整回答
反對 回復 2019-03-18
  • 2 回答
  • 0 關注
  • 705 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號