最近想了解一下Vue是怎麼實現數據雙向綁定的,瞭解到是基於Object.definProperty,在此記錄一下。javascript
Object.defineProperty 顧名思義,就是給對象定義一個屬性,總共有這麼幾種:java
不能同時設置訪問器 (get 和 set) 和 wriable 或 value,不然會錯,就是說(get 和 set)和(wriable 或 value中的任何一個)只能取其一this
隨便寫點東西spa
<script> var c = { year:2017 }; Object.defineProperty(c,'a',{
// 注意這裏不能直接不能對a直接賦值,不然會無限回調 set:function(val){console.log(`I set the value ${val}`);}, get:function(){return this} }) </script>
分別賦值和取值:雙向綁定
set的時候正確的調用了方法,可是取值的時候若是寫return this.acode
就會報錯,棧溢出。看上面的圖咱們就明白了,a的值指向自身,若是直接打印就會無限回調,雖然咱們不能取到a,但咱們能經過a取到其餘屬性對象
修改get:blog
set:function(val){ this.year = val }, get:function(e){ return this.year }