Reflect对象
一.Reflect对象基础
Reflect对象是ES6出现的新的API,用于操作对象内部的方法。
特点:
1. 对于操作有明确的返回结果。如返回布尔值表示操作成功与否
2. 和Proxy的拦截方法一一对应,实现操作的默认行为
3.将in,delete,new等命令,用方法实现
4.该对象的方法将逐渐取代Object上的方法
二.静态方法
和Proxy的拦截方法一一对应,一共有13个方法;
所有方法的第一个参数都必须是对象。否则报错。
返回布尔值的方法有:
1. Reflect.set(target,propKey, value, receiver)
target[propKey] = value; // 操作是否成功
如果传入receiver,则this指向receiver
2. Reflect.has(target, propKey)
propKey in target
3. Reflect.deleteProperty(target, propKey)
delete target[propKey] // 操作是否成功
4. Reflect.setPrototypeOf(target, proto)
target.__proto__ = proto; // 操作是否成功
5. Reflect.defineProperty(target, propKey, propDescriotor)
Object.defineProperty(target, propKey, propDescriptor)//操作是否成功
6. Reflect.isExtensible(target)
Object.isExtensible(target)
7.Reflect.preventExtensions(target)
Object.preventExtensions(target)// 返回操作是否成功
返回非布尔值的方法有:
1. Reflect.get(target, propKey,receiver)
target[propKey]
1.如果方法中传入了receiver参数,那么,如果getter方法中有this,this指向receiver
2.如果不存在,返回undefined
2. Reflect.construct(Target, args)
new Target(...args)
3. Reflect.getPrototypeOf(target)
target.__proto__
4. Reflect.apply(fn, thisArg, args)
Function.prototype.apply.call(target, thisArg, args);
5. Reflect.getOwnPropertyDescriptor(target, propKey)
Object.getOwnPropertyDescriptor(target, propKey)
6.Reflect.ownKeys(target)
Object.getOwnPropertyNames(target) +
Object.getOwnPropertySymbols(target)
Reflect对象的更多相关文章
- es6 Reflect对象详解
Reflect是ES6为操作对象而提供的新API,而这个API设计的目的只要有: 将Object对象的一些属于语言内部的方法放到Reflect对象上,从Reflect上能拿到语言内部的方法.如:Obj ...
- ES6引入的Reflect对象目的何在?
Reflect对象其实就是为了取代Object对象.取代原因有一下几点: 1)Object对象的一些内部方法放在了Reflect上面,比如:Object.defineProperty.主要是优化了语言 ...
- ES6新特性:Javascript中的Reflect对象
Reflect介绍: Reflect这个对象在我的node(v4.4.3)中还没有实现, babel(6.7.7)也没有实现 ,新版本的chrome是支持的, ff比较早就支持Proxy和Reflec ...
- 12,13 Proxy和Reflect
Proxy和Reflect Proxy(代理) Proxy用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种"元编程"(meta programming),即对编程 ...
- ES6 Proxy和Reflect(下)
construct() construct方法用于拦截new命令. var handler = { construct (target, args) { return new target(...ar ...
- es6重点笔记:Symbol,Set,Map,Proxy,Reflect
一,Symbol 原始数据类型,不是对象,它是JavaScript第七种数据类型,表示独一无二的值.Symbol是通过Symbol函数生成的: let s = Symbol(); typeof s / ...
- es6学习笔记-Proxy、Reflect、Promise
Proxy Proxy 用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种“元编程”(meta programming),即对编程语言进行编程. Proxy 可以理解成,在目标对象之前 ...
- 深入理解 ES6中的 Reflect
阅读目录 一:Reflect.get(target, name, receiver) 二:Reflect.set(target,name,value,receiver) 三:Reflect.apply ...
- ES6走一波 Proxy/Reflect
Proxy:像拦截器,对目标对象修改等进行拦截,是一种元编程(meta programming),即修改JS语言本身. //生成proxy实例,两个参数都是对象,targetObj是要拦截的目标对象, ...
随机推荐
- 【数据结构 Python & C++】顺序表
用C++ 和 Python实现顺序表的简单操作 C++代码 // Date:2019.7.31 // Author:Yushow Jue #include<iostream> using ...
- Python习题004
作业一:三迁举办选“帅气男孩”,评委打分可以输入打分,要求分数必须大于5,小于10: 方法一 i = 1 while i < 6: score = input("请%d评委打分:&qu ...
- SpringBoot 第一篇:HelloWorld 跑起来
背景 金融行业从业快十年,作为银行系开发人员来说开源框架了解不多非常正常,因为银行系的运行平台,基本上不会采购小厂商集合开源框架自建的产品,竞标的产品没有几十个成功案例,你也进不了这个门槛(有关系的除 ...
- reference website
reference website cplusplus http://www.cplusplus.com/reference/ cppreference https://en.cppreference ...
- 如何判断 Session是否存在
相信很多人都跟我一样,在写网页中有些位置通过其他网页设置了 Session然后跳转到目标页面就需要要用 Session,但是那个位置如果是直接打开的就用不到 Session,那么问题就来了,例如:系统 ...
- 如何在vscode中调试vue-cli项目?
一:参考官网文档,写的还是很清楚的:https://cn.vuejs.org/v2/cookbook/debugging-in-vscode.html 二:需要安装的东西和初始项目 2.1 用vue ...
- vue去哪儿网项目环境配置
一.首先安装node.js 根据自己的(windows或mac)系统进行安装node,在开发环境中一般安装LTS版本.安装成功后,在终端输入"node -v"和"npm ...
- linux shell数值比较和字符串比较
说明: 1. 把字符串当成整型进行比较,由于abcd等字符对不上0123当程序尝试去转成二进制时无法完成转换,所以用于数值比较的运算不能用于字符串比较:但是把整型当成字符串进行比较,0123这些数值完 ...
- 2.TCP/IP的三次握手与四次挥手
参考文章:http://357742954.blog.51cto.com/368705/1317226 TCP(Transmission Control Protocol) 传输控制协议,是一个面向连 ...
- 【Hibernate】持久化对象状态及以及缓存
一.持久化类状态 1.1 三种持久化对象的状态 1.2 区分三种状态 1.3 三种状态对象转换 1.瞬时态 2.持久态 3.脱管态 4.持久态对象有自动更新数据库的能力 一.持久化类状态 1.1 三种 ...