一、写在前面Reflect
的作用就是将部分Object
上的方法,放到Reflect
中,这样就减少了Object
对象的体积。
二、例子不使用Reflct的写法
let info = {
name: 'dmc',
age: 20
}
let proxyInfo = new Proxy(info, {
get(target, key, receiver) {
return target[key]
},
set(target, key, newValue, receiver) {
target[key] = newValue
}
})
console.log(proxyInfo.name)
proxyInfo.name = 'dl'
console.log(proxyInfo)
使用Reflect
let info = {
name: 'dmc',
age: 20
}
let proxyInfo = new Proxy(info, {
get(target, key, receiver) {
return Reflect.get(target,key, receiver)
},
set(target, key, newValue, receiver) {
Reflect.set(target, key, newValue, receiver)
},
has(target, key) {
return Reflect.has(target, key)
}
})
console.log(proxyInfo.name)
proxyInfo.name = 'dl'
console.log('name' in proxyInfo) //trues
三、作用
1、前面我们已经知道Reflect可以减轻Object的负担。
2、让对象操作都变成函数行为。
3、proxy上的方法在Reflect中都可以找到对应的方法。也就是说我们在Proxy中执行某一个方法的时候,都可
以在Reflect中找到默认行为,如果我们让需要执行某一些操作时,可以添加一些额外的代码。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/weixin_47450807/article/details/123440896
内容来源于网络,如有侵权,请联系作者删除!