1. 程式人生 > >vue的響應式原理

vue的響應式原理

es5 start 被調用 too 調用 value prop 內部 一個

  Vue 最獨特的特性之一,是其非侵入性的響應式系統。數據模型僅僅是普通的 JavaScript 對象。而當修改它們時,視圖會進行更新。

  

  當我們把一個普通的 JavaScript 對象傳給 Vue 實例的 data 選項,Vue 將遍歷此對象所有的屬性,並使用 Object.definedProperty 把這些屬性全部轉為 getter/setter 。Object.defineProperty 是 ES5 中一個無法 shim 的特性,這也就是為什麽 Vue 不支持 IE8 以及更低版本瀏覽器。

  這些 getter/setter 對用戶來說是不可見的,但是在內部它們讓 Vue 追蹤依賴,在屬性被訪問和修改時通知變化。這裏需要註意的問題是瀏覽器控制臺在打印數據對象時 getter/setter 的格式化並不同,所以你可能需要安裝 vue-devtools 來獲取更加友好的檢查接口。

  每個組件實例都有相應的 watcher 實例對象,它會在組件渲染的過程中把屬性記錄為依賴,之後當依賴項的 setter 被調用時,會通知 wacher 重新計算,從而致使它關聯的組件得以更新。

  受現代 JavaScript 的限制 (而且 Object.observe 也已經被廢棄),Vue 不能檢測到對象屬性的添加或刪除。由於 Vue 會在初始化實例時對屬性執行 getter/setter 轉化過程,所以屬性必須在 data 對象上存在才能讓 Vue 轉換它,這樣才能讓它是響應的。Vue 不允許在已經創建的實例上動態添加新的根級響應式屬性 (root-level reactive property)。然而它可以使用 Vue.set(object, key, value)

方法將響應屬性添加到嵌套的對象上: Vue.set( this.form, ‘startIndex‘, 1)

vue的響應式原理