Proxy
是 ES6
中新增的一个构造函数,它用于创建一个代理对象,可以拦截并自定义对象的基本操作,例如属性查找、赋值、枚举、函数调用等。
使用 Proxy
可以实现许多高级功能,例如数据绑定、校验、撤销/重做等。下面是一个简单的示例,它演示了如何使用 Proxy
来拦截对象的属性访问:
const target = {
message1: 'hello',
message2: 'world'
};
const handler = {
get: function(target, prop, receiver) {
if (prop === 'message2') {
return 'everyone';
}
return Reflect.get(...arguments);
}
};
const proxy = new Proxy(target, handler);
console.log(proxy.message1); // 输出: hello
console.log(proxy.message2); // 输出: everyone
在上面的代码中,我们首先定义了一个目标对象 target
和一个处理器对象 handler
。处理器对象中定义了一个 get
方法,用于拦截对目标对象属性的访问。
接着,我们使用 new Proxy(target, handler)
来创建一个代理对象。当我们访问代理对象的属性时,会调用处理器对象中的 get
方法。在这个方法中,我们可以自定义属性访问的行为。
在上面的示例中,当我们访问代理对象的 message2
属性时,处理器对象中的 get
方法会返回 'everyone'
,而不是目标对象中实际的值 'world'
。这样,我们就可以拦截并自定义对象的属性访问行为。