Reflect API 是 JavaScript 统一对象操作的内置工具集,提供与 Proxy trap 一一对应的静态方法,增强可控性、可预测性及元编程能力。
JavaScript 的 Reflect API 是一套用于操作对象的内置工具集,它把原本分散在 Object、function、proxy 等地方的底层操作统一成静态方法,并与 Proxy 的 trap(陷阱)一一对应。它的核心目的不是“让代码更炫”,而是让对象操作更可控、更可预测,尤其在元编程和代理场景中非常实用。
过去很多对象操作靠语法(如 obj[key]、delete obj.key)或 Object 静态方法(如 Object.defineProperty),但它们行为不一致、错误处理方式不同,也不支持拦截。Reflect 提供了标准化的方法调用形式:
Reflect.get(obj, key, receiver) → 替代 obj[key],支持自定义 getter 和 receiver 绑定Reflect.set(obj, key, value, receiver) → 替代 obj[key] = value,返回布尔值表示是否成功(不会静默失败)Reflect.has(obj, key) → 替代 key in obj,可用于 Proxy 中统一拦截 in 操作Reflect.deleteProperty(obj, key) → 替代 delete obj.key,同样返回布尔结果Reflect.defineProperty(obj, key, desc) → 类似 Object.defineProperty,但失败时抛错而非静默返回 falseReflect 方法的设计初衷就是为 Proxy 的 trap 提供默认行为。每个 trap 都能直接委托给对应的 Reflect[trap],避免重复实现,也保证语义一致:
get trap 中写 return Reflect.get(target, key, receiver),就等价于默认读取行为apply、construct、ownKeys)都有对应 Reflect 方法,无需查文档猜命名有些底层行为 Jav
aScript 语法根本不支持,Reflect 则补上了这些缺口:
Reflect.apply(func, thisArg, argsArray) → 精确模拟函数调用,比 func.apply() 更底层(不触发 apply trap,除非在 Proxy 中)Reflect.construct(target, args, newTarget?) → 实现 new Target(...args) 的逻辑,支持自定义构造器和原型链Reflect.getOwnPropertyDescriptor(obj, key) → 和 Object.getOwnPropertyDescriptor 行为一致,但属于 Reflect 体系,便于统一管理Reflect.ownKeys(obj) → 返回包括不可枚举、Symbol 键在内的所有自有属性键,比 Object.keys 或 Object.getOwnPropertyNames 更完整Reflect 方法普遍遵循“成功返回 true/结果,失败明确抛错”的原则,不像部分 Object 方法(如 Object.defineProperty)在非严格模式下静默失败:
Reflect.set() 在不可写属性上赋值,直接返回 false,而不是报错或忽略Reflect.defineProperty() 在非法描述符上会立即 throw TypeError,不依赖严格模式开关