利用 proxy 监视对象的变化

本文介绍了一种使用ES6的Proxy API实现MVVM模式的方法,通过get、defineProperty及deleteProperty方法监视对象属性的变化,并提供了简洁易懂的示例代码。

vue 对于 mvvm 的实现是基于 Object.defineProperty 来实现的, 对于 es6 而言有另外一种类似的监视对象属性变化的 api, 即使用代理 Proxy

对于这个 api 不熟悉的开发者可以点击这里

利用 porxy 代理对象的 get, defineProperty, deleteProperty 方法即可实现,代码简洁明了

const watch = (object, onChange) => {
   const handler = {
       /*  
           如果 target[property] 为对象时递归代理,否则返回属性值
           @param {object} target
           @param {string} property
           @param {object} [receiver]
       */
       get (target, property, receiver) {
           try {
               return new Proxy(target[property], handler)
           } catch (err) {
               return Reflect.get(target, property, receiver)
           }
       },
       
       /*
           当对象赋值的时候,触发的代理方法(如果有 set 代理, 则触发 set 代理,否则触发该方法)
           @param {object} target
           @param {string} property
           @param {object} descriptor
       */
       defineProperty (target, property, descriptor) {
           onChange() // 赋值时触发回调函数
           return Reflect.defineProperty(target, property, descriptor)
       },
       
       /*
           当删除对象属性时触发的代理方法
           @param {object} target
           @param {string} property
       */
       deleteProperty (target, property) {
           onChange() // 删除属性时触发回调函数
           return Reflect.deleteProperty(target, property)
       }
   }
   
   return new Proxy(object, handler)
}

// demo
let obj = {
   a: 123,
   b: {
       c: 333
   }
}
let i = 0
let watchObj = watch(obj, () => {console.log('Object changed:', ++i)})
watchObj.a = 333
// => 'Object changed: 1'
watchObj.b.c = 444
//=> 'Object changed: 2'
复制代码

参考链接

转载于:https://juejin.im/post/5a3b492ff265da432f314895

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值