Obect.definedProperty响应

本文深入探讨Vue2中响应式系统的实现机制,利用ES5的Object.defineProperty方法,通过get和set访问器创建数据绑定,实现视图更新。文章详细解释了依赖收集和通知过程,展示了如何在数据变化时自动触发视图更新。

在之前学习vue2时发现响应式的原理是利用Object.definedProperty方法实现数据的绑定,已达到响应式,这是ES5的方法。

语法:

Object.definedProperty(target,propKey,handler)

  • target:目标对象
  • propKey:属性名称的字符串
  • handler:对象描述符,有两个方法 get()和set()(双向数据绑定正是利用了这两个方法,即访问器),以及其他属性(configurable,enumerable,writable,默认是false)

- set():一旦属性被重新赋值,此方法被自动调用。

- get():一旦属性被访问读取,此方法被自动调用。

响应数据绑定例子:

let x;
let y;
let f = n=>n*100+100;

let active;
let onXChange=function(cb){
    active = cb;
    active();
    active = null;
}

class Dep{
    constructor(){
        this.deps = new Set();
    }
    depend(){
        if(active){            
            this.deps.add(active);            
        }
    }
    notify(){              
        this.deps.forEach(dep=>dep());
    }
}
let ref = initValue=>{
    let value = initValue;
    let dep = new Dep();
    return Object.defineProperty({},'value',{
        get(){
            dep.depend(); 
            return value;
        },
        set(newValue){
            value = newValue; 
            dep.notify();
        }
    })
}
x = ref(1);
onXChange(()=>{        
    y = f(x.value);
    console.log(y); // 1,2,3
})

x.value=2;
x.value=3;

 响应流程:

1. reg(1) => 返回x.value对象

2. onXChange 调用 回调赋值给 active,后执行

3. x.value =>触发get 方法 => this.deps = >active?add:''

4. f方法计算返回值

5. 当x.value发生改变,触发set 方法 => 存入值=> this.deps循环触发之前添加的回调方法执行,然后又从3开始,直到,x.value值没有变动

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值