vue的双向数据绑定原理

    xiaoxiao2022-07-07  235

    数据驱动/ 双向数据绑定的原理 / 深入响应式的原理

    Vue中VM改变,那么V也会改变 , 反之也是一样的, 我们称之为 ‘双向数据绑定’。这个是使用了es5中的一个特性,这个特性叫做 Object.definedPropty( obj, 对象的属性, 配置项)

    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,将数据修改,同时视图也会发生更新。
    最新回复(0)