Proxy可拦截对象操作,Reflect提供统一方法;如用set拦截赋值,将负数转为0,实现数据校验与代理控制。

JavaScript 中的 Proxy 和 Reflect 是一对强大的内置对象,它们让开发者能够更精细地控制对象的行为。Proxy 可以拦截并自定义对象的基本操作,而 Reflect 提供了一套统一的方法来执行这些操作,并与 Proxy 配合使用效果更佳。
Proxy 用于创建一个对象的代理,从而可以拦截和重新定义对该对象的基本操作(如属性读取、赋值、枚举等)。它接受两个参数:目标对象和一个“处理器”(handler)对象,handler 定义了要拦截的操作。
常见拦截方法包括:例如,实现一个自动将负数转为0的数值属性赋值:
const target = { score: 10 }; const proxy = new Proxy(target, { set(obj, prop, value) { if (prop === 'score' && valueReflect 不是构造函数,而是一个静态工具对象,提供与 Proxy handler 方法一一对应的方法。它的设计目的是让对象操作更可预测,并能更好地配合 Proxy 使用。
立即学习“Java免费学习笔记(深入)”;
使用 Reflect 的好处:比如,在 Proxy 中调用 Reflect 来保留原始行为:
const proxy = new Proxy({}, { get(target, property) { console.log(`访问属性 ${property}`); return Reflect.get(target, property); }, set(target, property, value) { console.log(`设置属性 ${property} 为 ${value}`); return Reflect.set(target, property, value); } }); proxy.name = "Alice"; // 打印:设置属性 name 为 Alice console.log(proxy.name); // 打印:访问属性 name,然后输出 Alice在编写 Proxy handler 时,推荐使用 Reflect 对应方法来完成默认操作。这样代码更清晰,也避免了 this 指向等问题。
例如,实现一个只读视图:
function createReadOnlyView(object) { return new Proxy(object, { set() { throw new Error("不可修改只读对象"); }, deleteProperty() { throw new Error("不可删除只读对象的属性"); }, setPrototypeOf() { throw new Error("不可修改原型"); } }); }如果需要在拦截中保留原逻辑,就用 Reflect:
set(target, property, value, receiver) { // 可以添加验证逻辑 if (typeof value !== 'number') { console.warn(`${property} 必须是数字`); return false; } // 使用 Reflect.set 确保正确触发 setter(包括继承链上的) return Reflect.set(target, property, value, receiver); }基本上就这些。Proxy 提供拦截能力,Reflect 提供标准操作接口,两者结合能让 JavaScript 对象行为更加灵活可控。理解它们的协作方式,有助于写出更健壮的元编程代码。
以上就是JavaScript Proxy与Reflect API的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号