Java的反射机制是在编译阶段不知道是哪个类被加载,而是在运行的时候才加载、执行
es6中Reflect对象设计的目的:
1、未来将会把Object对象里语言内部的方法移至Reflect
对象上(Object.defineProperty
)
2、修改某些Object
方法的返回结果,让其变得更合理。比如,Object.defineProperty(obj, name, desc)
在无法定义属性时,会抛出一个错误,而Reflect.defineProperty(obj, name, desc)
则会返回false
。
3、让Object操作都变成函数行为。比如,'assign' in Object
=》 Reflect.has(Object, 'assign')
4、Reflect
对象的方法与Proxy
对象的方法一一对应,只要是Proxy
对象的方法,就能在Reflect
对象上找到对应的方法。这就让Proxy
对象可以方便地调用对应的Reflect
方法,完成默认行为,作为修改行为的基础。也就是说,不管Proxy
怎么修改默认行为,你总可以在Reflect
上获取默认行为。
有了Reflect
对象以后,很多操作会更易读。
静态方法
- Reflect.apply(target, thisArg, args)
等同于
Function.prototype.apply.call(func, thisArg, args)
,用于绑定this
对象后执行给定函数。 - Reflect.construct(target, args)
Reflect.construct
方法等同于new target(...args)
,这提供了一种不使用new
,来调用构造函数的方法。 - Reflect.get(target, name, receiver) 查找并返回
target
对象的name
属性,如果没有该属性,则返回undefined
- Reflect.set(target, name, value, receiver) 设置
target
对象的name
属性等于value
- Reflect.defineProperty(target, name, desc) 基本等同于
Object.defineProperty
,用来为对象定义属性。未来,后者会被逐渐废除,请从现在开始就使用Reflect.defineProperty
代替它。 - Reflect.deleteProperty(target, name) 等同于
delete obj[name]
,用于删除对象的属性。 - Reflect.has(target, name) 对应
name in obj
里面的in
运算符。 - Reflect.ownKeys(target) 用于返回对象的所有属性,基本等同于
Object.getOwnPropertyNames
与Object.getOwnPropertySymbols
之和。 - Reflect.isExtensible(target) 对应
Object.isExtensible
,返回一个布尔值,表示当前对象是否可扩展。 - Reflect.preventExtensions(target) 对应
Object.preventExtensions
方法,用于让一个对象变为不可扩展。它返回一个布尔值,表示是否操作成功。 - Reflect.getOwnPropertyDescriptor(target, name) 基本等同于
Object.getOwnPropertyDescriptor
,用于得到指定属性的描述对象,将来会替代掉后者 - Reflect.getPrototypeOf(target)
Reflect.getPrototypeOf
方法用于读取对象的__proto__
属性,对应Object.getPrototypeOf(obj)
。 - Reflect.setPrototypeOf(target, prototype)
Reflect.setPrototypeOf
方法用于设置目标对象的原型(prototype),对应Object.setPrototypeOf(obj, newProto)
方法。它返回一个布尔值,表示是否设置成功。