JavaScript反射是什么意思,用法是怎样
Admin 2022-06-23 群英技术资讯 566 次浏览
Reflect
是一个内置的对象,它提供拦截 JavaScript
操作的方法。这些方法与 proxy handlers (en-US) 的方法相同。 Reflect
不是一个函数对象,因此它是不可构造的。那么它到底是什么?根据上面文件介绍会发现它和 Proxy
极像,都是获取执行函数本身信息。主要是区别在于所有的函数对象属性过于复杂,而且额外增加可能会导致程序行为不合理,所以扩展 Reflect
函数来专门对函数对象处理调用方法,构造对象,获取或者设置属性等相关操作。
Reflect
里面所有的方法都是静态方法,不需要构造函数或者实例化它。
Reflect.apply
(target
, thisArgument
, argumentsList
)、对一个函数进行调用操作,同时可以传入一个数组作为调用参数。和 Function.prototype.apply()
功能类似。Reflect.construct
(target
, argumentsList[, newTarget\]
)对构造函数进行 new 操作,相当于执行 new target
(...args) 。Reflect.defineProperty
(target
, propertyKey
, attributes
)和 Object.defineProperty()
类似。如果设置成功就会返回 true
Reflect.deleteProperty(target, propertyKey)
作为函数的 delete
操作符,相当于执行 delete target[name]
。Reflect.get(target, propertyKey[, receiver\])
获取对象身上某个属性的值,类似于 target[name]
。Reflect.getOwnPropertyDescriptor(target, propertyKey)
类似于 Object.getOwnPropertyDescriptor()
。如果对象中存在该属性,则返回对应的属性描述符, 否则返回 undefined
.Reflect.getPrototypeOf(target)
类似于 Object.getPrototypeOf()
。Reflect.has(target, propertyKey)
判断一个对象是否存在某个属性,和 in
运算符 的功能完全相同。Reflect.isExtensible(target)
类似于 Object.isExtensible() .
Reflect.ownKeys(target)
返回一个包含所有自身属性(不包含继承属性)的数组。(类似于 Object.keys()
, 但不会受 enumerable
影响 ).Reflect.preventExtensions(target)
类似于 Object.preventExtensions()
。返回一个 Boolean
。Reflect.set(target, propertyKey, value[, receiver\])
将值分配给属性的函数。返回一个 Boole
an ,如果更新成功,则返回 true
。Reflect.setPrototypeOf(target, prototype)
设置对象原型的函数. 返回一个 Boolean
, 如果更新成功,则返回 true
。比如现在有个函数:
class Person { constructor(firstName, lastName) { this.firstName = firstName this.lastName = lastName } get getName() { return this.firstName + ' ' + this.lastName } }
正常使用只需要进行实例化即可:
const person = new Person('Jaxson', 'Wang') console.log(person.getName) // Jaxson Wang
可以使用 Reflect.construct() 方法来创建对象:
const person = Reflect.construct(Person, ['Jaxson', 'Wang']) console.log(person) // Jaxson Wang
Reflect 对象经常和 Proxy 代理一起使用,原因有三点:
Reflect
提供的所有静态方法和 Proxy
第2个 handle
参数方法是一模一样的。Proxy get/set()
方法需要的返回值正是 Reflect
的get/set
方法的返回值,可以天然配合使用,比直接对象赋值/获取值要更方便和准确。receiver
参数具有不可替代性。免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要给大家介绍的关于vue路由懒加载的内容,很多刚接触vue的朋友,可能对于vue路由懒加载是什么以及实现方法不是很清楚,因此下面小编就带大家来了解一下。
在javascript中,可以利用replaceChild()方法来替换页面元素,该方法的作用就是用新节点替换某个子节点,语法“父节点.replaceChild(新节点,需要替换的老节点)”。
今天给大家分享的是关于基于jQuery封装的拖拽事件,下文有详细的代码及注释,对大家学习和理解封装以及拖拽事件都有一定的帮助,有需要的朋友可以参考。
这篇文章给大家分享的是Node.js的事件循环的实现,对于事件循环的六个阶文中都有很详细的介绍,下文还有示例可以参考,对大家学习和理解Node.js的事件循环会有帮助,有需要的朋友可以了解看看这篇,接下来就跟随小编一起学习一下吧。
小程序怎样实现分页查询列表的模板,及代码是什么?下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008