版权声明:转载请注明出处 https://blog.csdn.net/qdmoment/article/details/85235864
proxy和reflect都是es6为了更好的操作对象而提供的新的API,接下来探讨一下二者的作用,联系。
设计proxy,reflect的作用:
proxy的作用:
Proxy的设计目的在于(修改编程语言),修改某些操作方法的默认行为,
等同于在语言层面作出修改,是元编程(meta programming) 例如修改set,get方法
reflect的作用:
1,映射一些明显属于对象语言内部的方法,目前是共存于Object
和Reflect上,未来只在Reflect上
2,修改一些Object
上的方法返回的结果,减少异常抛出,使其变得更加合理
3,让Object
操作都变成函数行为(主要的作用)
4,Reflect
对象的方法与Proxy
对象的方法一一对应(主要的作用)
proxy和reflect的方法:
proxy的实例方法:
get() | set() | apply() | has() | cunstruct() | deleteProperty() | defineProperty() |
getOwnPropertyDescriptor() | getPrototypeOf() | isExtensible() | ownKeys(), | preventExtensions() | setPrototypeOf() |
var person = {
name: "张三"
};
var proxy = new Proxy(person, {
get: function(target, property) {
if (property in target) {
return target[property];
} else {
throw new ReferenceError("Property \"" + property + "\" does not exist.");
}
}
});
注:目标对象内部的this
关键字会指向 Proxy 代理
自身方法:Proxy.revocable
方法返回一个可取消的 Proxy 实例
reflect的静态方法:
和proxy相对应,reflect有13个静态方法,分别一一对应于proxy的实例方法
Reflect.apply(target, thisArg, args) | Reflect.construct(target, args) |
Reflect.get(target, name, receiver) | Reflect.set(target, name, value, receiver) |
Reflect.defineProperty(target, name, desc) | Reflect.deleteProperty(target, name) |
Reflect.has(target, name) | Reflect.ownKeys(target) |
Reflect.isExtensible(target) | Reflect.preventExtensions(target) |
Reflect.getOwnPropertyDescriptor(target, name) | Reflect.getPrototypeOf(target) |
Reflect.setPrototypeOf(target, prototype) |
proxy和reflect联系:proxy的实例方法和reflect的静态方法一一对应
实例:观察者模式的实现
const queuedObservers = new Set();
const observe = fn => queuedObservers.add(fn);//接收一个函数fn
const observable = obj => new Proxy(obj, {set});//接收一个对象obj,采用set函数拦截设置obj
function set(target, key, value, receiver) {
const result = Reflect.set(target, key, value, receiver);
queuedObservers.forEach(observer => observer());
return result;
}