Object.definedPropty
配置项: value:属性的值enumerable:是否能枚举,也就是否能在for…in循环中遍历出来或在Object.keys中列举出来默认为false。writable:为false对象属性的值则不能被改变。configurable:如果为fals,就不能再设置他的(value,writable,configurable)。e访问器get() 和 set()访问器
set();一旦属性被重新赋值,此方法被自动调用。get();一旦属性被访问读取,此方法被自动调用。 不能同时设置访问器 (get 和 set) 和 wriable 或 value,否则会错。简单双向数据绑定原理
<input type="text"> <div class="box"></div> let input = document.querySelector('.input'); let div = document.querySelector('.div'); let obj = { a: "I love you cll" } Object.defineProperty(obj, 'a', { get() { return null; }, set(v) { div.innerHTML = v; } // value: 'cll love you' //不能和访问器同时设置 }) input.onkeyup = function() { obj.a = input.value; } div.innerHTML = obj.a;实现方式:
当我们将数据写在data选项时,Vue会通过observer将data对象中的所有的属性都设置上getter和setter当我们将数据绑定在视图时,自动触发getter,会将默认值,展示在视图当我们通过视图修改数据是,会自动触发setter,将数据修改,同时视图也会发生更新。