vue3中实现响应式原理Proxy 和 Reflect。代码演示

实现原理:
通过 Proxy(代理):拦截对象中任意属性的变化(包括读写,属性的添加,删除等)。
通过 Reflect(反射):对被代理的对象(也就是源对象)属性进行操作。

eg:1
let person = {
      name: "你好",
      age: 18,
    };
    
// 模拟vue3中实现响应式
const p = new Proxy(person, {
  // 读取属性时可调用
  get(target, propName) {
    console.log(`我读取了p身上的${propName}属性`);
    return target[propName];
  },
  // 有人修改或者追加某个属性时调用(新增、修改)
  set(target, propName, value) {
    console.log(`我修改了p身上的${propName}属性,去更新界面`);
    target[propName] = value;
  },
  // 有人删除某个属性时调用
  deleteProperty(target, propName) {
    console.log(`我删除了p身上的${propName}属性,去更新界面`);
    return delete target[propName];
  },
});


eg2:
 let obj = {
      a: 1,
      b: 2,
    };
// 通过 Reflect.defineProperty 反射对象 去操作
// 这里的Reflect 是有返回值的,
// 如果你重复定义了某个属性,那么就会返回 false,不过是页面不会报错,
let x1 = Reflect.defineProperty(obj, "c", {
  get() {
    return 3;
  },
});
console.log(x1);
let x2 = Reflect.defineProperty(obj, "c", {
  get() {
    return 4;
  },
});
console.log(x2);
if (x2) {
  console.log("执行xxx操作成功");
} else {
  console.log("执行xxx操作失败");
}

通过上述两个例子 ,可以总结出真正的实现原理 :

    const p = new Proxy(person, {
      // 读取属性时可调用
      get(target, propName) {
        console.log(`我读取了p身上的${propName}属性`); 
        return Reflect.get(target, propName);
      },
      // 有人修改或者追加某个属性时调用(新增、修改)
      set(target, propName, value) {
        console.log(`我修改了p身上的${propName}属性,去更新界面`); 
        Reflect.set(target, propName, value);
      },
      // 有人删除某个属性时调用
      deleteProperty(target, propName) {
        console.log(`我删除了p身上的${propName}属性,去更新界面`); 
        return Reflect.defineProperty(target, propName);
      },
    });
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值