ES6 Reflect
Reflect 反射?字面上是,但是实际上它的作用只是配合 Proxy 实现,深入使用反射,确实能进行一些数据元操作,那么该如何编写呢?
简单谈谈
Reflect:反射,语言层面上的内容,在 ES6 中其出现的目的主要有以下几个:
- 将
Object下属于语言内部的方法,放到Reflect上,让Object更加纯粹。 - 修正之前在
Object下的一些方法的返回值不合理照成的逻辑混乱。 - 将命令式的行为变成函数行为,如:
name in obj==>Reflect.has(obj, name)。 - 与
Proxy下的方法一一对应,Proxy可以更方便的完成默认行为的调用。
拥有的方法
目前一共有 13 个方法,与 Proxy 下的方法一一对应,直接调用这些方法就完成了 Proxy 默认的行为。
- Reflect.apply(target, ctx, args)
- Reflect.construct(target, args)
- Reflect.get(target, key, receiver)
- Reflect.set(target, key, value, receiver)
- Reflect.defineProperty(target, key, desc)
- Reflect.deleteProperty(target, key)
- Reflect.has(target, key)
- Reflect.ownKeys(target)
- Reflect.isExtensible(target)
- Reflect.preventExtensions(target)
- Reflect.getOwnPropertyDescriptor(target, key)
- Reflect.getPrototypeOf(target)
- Reflect.setPrototypeOf(target, prototype)
其作用与 Proxy 中的差不多,只不过一个进行拦截,一个进行操作。