Reflect 是 JavaScript 暴露内部操作的静态对象,方法命名统一、返回布尔值、行为更底层;与 Proxy 协作,Proxy 拦截操作,Reflect 执行默认行为,实现职责分离与元编程规范。
Reflect 是 JavaScript 的内置静态对象,它把原本隐式执行的语言内部操作(比如读属性、设值、调用函数)暴露为显式的函数方法。它本身不能被构造,也没有实例,所有方法都是静态的,就像 Math 一样。
它让对象操作更规范、可预测、易组合:
Reflect.get() 对应 obj.prop,Reflect.set() 对应 obj.prop = val
Reflect.deleteProperty()),避免抛异常Object 静态方法,行为更底层、更一致(例如 Reflect.ownKeys() 比 Object.keys() 更完整,能拿到不可枚举和 Symbol 键)
配——它的每个方法都与 Proxy handler 的 trap 一一对应Proxy 负责“拦截”,Reflect 负责“执行默认行为”。写 Proxy 时,几乎总是配合 Reflect 使用,否则容易出错或丢失原始语义:
target[prop],而用 Reflect.get(target, prop, receiver) —— 它自动处理 receiver(即 this 绑定),避免原型链访问出错target[prop] = value,而用 Reflect.set(target, prop, value, receiver) —— 它返回布尔值,且尊重 setter、writable 等属性描述符apply 或 construct trap 中,用 Reflect.apply() 或 Reflect.construct() 可安全复现原行为职责分离更清晰:
Reflect.setPrototypeOf() 已是推荐方式,Object.setPrototypeOf() 被标记为不推荐)基本上就这些。用 Proxy 拦截,用 Reflect 执行——两者搭在一起,才是现代 JS 元编程的正确姿势。