Reflect API提供统一函数化方式操作对象,支持属性读写(Reflect.get/set)、方法调用(Reflect.apply)、实例构造(Reflect.construct)及元信息查询(如has、ownKeys),相比传统操作更安全且与proxy协同更佳。

javaScript的Reflect API为元编程提供了更简洁、更一致的方式,它允许你在运行时动态操作对象的行为,比如访问属性、调用方法、创建实例等。相比传统的操作方式,Reflect方法更函数化,也与Proxy配合更自然。
1. 使用 Reflect.get 和 Reflect.set 操作属性
你可以用 Reflect.get 和 Reflect.set 安全地读取和设置对象属性,尤其适合在不确定对象结构时使用。
- 支持传入接收者(receiver),这对getter/setter中的 this 指向很重要
- 返回布尔值表示设置是否成功
示例:
const obj = { name: 'Alice', get greeting() { return `Hello, ${this.name}`; } }; // 获取属性 console.log(Reflect.get(obj, 'greeting')); // "Hello, Alice" // 设置属性 Reflect.set(obj, 'name', 'Bob'); console.log(Reflect.get(obj, 'greeting')); // "Hello, Bob"
2. 动态调用方法:Reflect.apply
用 Reflect.apply 可以像 call 或 apply 一样调用函数,但语法更清晰,也更适合封装通用逻辑。
立即进入“豆包AI人工智官网入口”;
立即学习“豆包AI人工智能在线问答入口”;
- 明确指定目标函数、this 上下文和参数数组
- 常用于高阶函数或拦截调用场景
示例:
function sum(a, b) { return a + b; } const result = Reflect.apply(sum, null, [3, 5]); console.log(result); // 8
3. 动态构造实例:Reflect.construct
用 Reflect.construct 可以动态创建类或构造函数的实例,相当于 new 的函数化版本。
- 可以传入构造函数和参数数组
- 还能指定不同的原型(通过第三个参数)
示例:
class Person { constructor(name) { this.name = name; } } const p = Reflect.construct(Person, ['Charlie']); console.log(p.name); // "Charlie"
4. 元信息查询:has、ownKeys、getOwnPropertyDescriptor
Reflect 提供了一系列方法来检查对象的元信息,比 Object 静态方法更贴近底层操作。
- Reflect.has(obj, key) 等价于 in 操作符
- Reflect.ownKeys(obj) 返回所有自有键(包括 symbol)
- Reflect.getOwnPropertyDescriptor(obj, key) 获取属性描述符
示例:
const obj = { a: 1 }; obj[Symbol('secret')] = 2; console.log(Reflect.has(obj, 'a')); // true console.log(Reflect.ownKeys(obj)); // ['a', Symbol(secret)]
基本上就这些。Reflect API 让你以统一、可预测的方式操作对象,特别适合与 Proxy 一起实现拦截、验证、日志等元编程功能。不复杂但容易忽略的是,它的每个方法都返回标准结果,便于错误处理和逻辑判断。


