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

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

vue雙向綁定問題

vue雙向綁定問題

慕森王 2019-03-18 14:58:07
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 回答

?
守著星空守著你

TA貢獻1799條經驗 獲得超8個贊

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

查看完整回答
反對 回復 2019-03-18
?
飲歌長嘯

TA貢獻1951條經驗 獲得超3個贊

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

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);
        }
    }
}

推薦個源碼解讀-Vue技術內幕


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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