Reflect

该新特性属于 ECMAScript 2015(ES6)规范,在使用时请注意浏览器兼容性。

Reflect 对象提供了若干个能对任意对象进行某种特定的可拦截操作(interceptable operation)的方法。

描述

和其他大多数全局对象不同的是,Reflect 并不是一个构造函数,你不需要使用 new 运算符来构造它的实例。下面的所有方法都是它的静态方法(就和 Math 对象身上的一样)。

方法

Reflect 对象提供了 14 个静态方法,它们的名字刚好和那 14 个代理处理器方法的名字相同,这 14 个方法中有几个刚好在 Object 对象身上也存在同名方法,虽然它们功能类似,但也存在细微差异。

Reflect.apply()
对一个函数进行调用操作,同时可以传入一个数组作为调用参数。和 Function.prototype.apply() 功能类似。
Reflect.construct()
对构造函数进行 new 操作,相当于执行 new target(...args)。
Reflect.defineProperty()
Object.defineProperty() 类似。
Reflect.deleteProperty()
删除对象的某个属性,相当于执行 delete target[name]。
Reflect.enumerate()
该方法会返回一个包含有目标对象身上所有可枚举的自身字符串属性以及继承字符串属性的迭代器,for...in 操作遍历到的正是这些属性。
Reflect.get()
获取对象身上某个属性的值,类似于 target[name]。
Reflect.getOwnPropertyDescriptor()
类似于 Object.getOwnPropertyDescriptor()
Reflect.getPrototypeOf()
类似于 Object.getPrototypeOf()
Reflect.has()
判断一个对象是否存在某个属性,和 in 运算符 的功能完全相同。
Reflect.isExtensible()
类似于 Object.isExtensible().
Reflect.ownKeys()
返回一个包含所有自身属性(不包含继承属性)的数组。
Reflect.preventExtensions()
类似于 Object.preventExtensions()
Reflect.set()
设置对象身上某个属性的值,类似于 target[name] = val。
Reflect.setPrototypeOf()
类似于 Object.setPrototypeOf()

规范

规范名称 规范状态 备注
ECMAScript 2015 (6th Edition, ECMA-262)
Reflect
Standard

浏览器兼容性

Feature Chrome Edge Firefox (Gecko) Internet Explorer Opera Safari
Basic support 49.0 (Yes) 42 (42) 未实现 未实现 10
Feature Android Chrome for Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile
Basic support 49.0 49.0 42.0 (42) 未实现 未实现 10

相关链接

文档标签和贡献者

 此页面的贡献者: wzx, ziyunfei
 最后编辑者: wzx,