Reflect API 是 JavaScript 统一对象操作的内置工具集,提供与 Proxy trap 一一对应的静态方法,增强可控性、可预测性及元编程能力。

JavaScript 的 Reflect API 是一套用于操作对象的内置工具集,它把原本分散在 Object、function、proxy 等地方的底层操作统一成静态方法,并与 Proxy 的 trap(陷阱)一一对应。它的核心目的不是“让代码更炫”,而是让对象操作更可控、更可预测,尤其在元编程和代理场景中非常实用。
统一对象操作接口,替代零散语法和 Object 方法
过去很多对象操作靠语法(如 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,但失败时抛错而非静默返回 false
与 Proxy 深度配合,实现干净的拦截逻辑
Reflect 方法的设计初衷就是为 Proxy 的 trap 提供默认行为。每个 trap 都能直接委托给对应的 Reflect[trap],避免重复实现,也保证语义一致:
- 在
gettrap 中写return Reflect.get(target, key, receiver),就等价于默认读取行为 - 想加日志?只在调用前/后插入代码,主体逻辑仍由 Reflect 承担
- 所有 trap(如
apply、construct、ownKeys)都有对应 Reflect 方法,无需查文档猜命名
提供语法无法表达的操作能力
有些底层行为 JavaScript 语法根本不支持,Reflect 则补上了这些缺口:
立即学习“Java免费学习笔记(深入)”;
-
Reflect.apply(func, thisArg, argsArray)→ 精确模拟函数调用,比func.apply()更底层(不触发applytrap,除非在 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,不依赖严格模式开关 - 这种一致性让防御性编程和运行时检查更可靠,尤其适合构建框架或工具库










