ES6 入门—ES6 Reflect 与 Proxy

},

};

// 最后创建一个 Proxy 实例,

let pro = new Proxy(target, handler);

pro.age = 30;

pro.name = “呵呵”;

console.log(pro.age);

console.log(pro.name);




在终端使用 node 命令运行,效果如下:  

![请添加图片描述](https://img-blog.csdnimg.cn/d974896ad4894049be4a5df1dafcc398.png)



[]( )2.3. has 方法

------------------------------------------------------------------------------



用于拦截 HasProperty 操作,即在判断 target 对象是否存在 propKey 属性时,会被这个方法拦截。此方法不判断一个属性是对象自身的属性,还是继承的属性。



has(target, propKey)




此方法不拦截 for … in 循环。



示例代码:



let handler = {

has: function(target, propKey){

    console.log("handle has");

    return propKey in target;

}

}

let exam = {name: “Tom”}

let proxy = new Proxy(exam, handler)

‘name’ in proxy;

// handle has

// true




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/802c276245a647c58dadb67658bf819d.png)



[]( )2.4. construct 方法

------------------------------------------------------------------------------------



用于拦截 new 命令。返回值必须为对象。



construct(target, args);




新建 test3.js 文件,代码如下:



let handler = {

construct: function (target, args, newTarget) {

console.log("handle construct");

return Reflect.construct(target, args, newTarget);

},

};

class Exam {

constructor(name) {

this.name = name;

}

}

let ExamProxy = new Proxy(Exam, handler);

let proxyObj = new ExamProxy(“Tom”);

console.log(proxyObj);

// handle construct

// exam {name: “Tom”}




在终端使用 node 命令运行,效果如下:  

![请添加图片描述](https://img-blog.csdnimg.cn/768da35fd03d4ebb940e59112f5fcdc4.png)



[]( )三、Reflect

============================================================================



ES6 中将 Object 的一些明显属于语言内部的方法移植到了 Reflect 对象上(当前某些方法会同时存在于 Object 和 Reflect 对象上),未来的新方法会只部署在 Reflect 对象上。



Reflect 对象对某些方法的返回结果进行了修改,使其更合理。



Reflect 对象使用函数的方式实现了 Object 的命令式操作。



接下来讲一讲它的各种静态方法。



[]( )四、get 方法的使用

==============================================================================



Reflect.get(target, name, receiver);




查找并返回 target 对象的 name 属性。



let exam = {

name: "Tom",

age: 24,

get info(){

    return this.name + this.age;

}

}

Reflect.get(exam, ‘name’); // “Tom”

// 当 target 对象中存在 name 属性的 getter 方法, getter 方法的 this 会绑定 // receiver

let receiver = {

name: "Jerry",

age: 20

}

Reflect.get(exam, ‘info’, receiver); // Jerry20

// 当 name 为不存在于 target 对象的属性时,返回 undefined

Reflect.get(exam, ‘birth’); // undefined

// 当 target 不是对象时,会报错

Reflect.get(1, ‘name’); // TypeError




在终端使用 node 命令运行:



![请添加图片描述](https://img-blog.csdnimg.cn/52586f4f8dc040c9a6a840900496c727.png)



[]( )五、set 方法的使用

==============================================================================



Reflect.set(target, name, value, receiver);




将 target 的 name 属性设置为 value。返回值为 boolean ,true 表示修改成功,false 表示失败。当 target 为不存在的对象时,会报错。



示例代码:



let exam = {

name: "Tom",

age: 24,

set info(value) {

    return this.age = value;

}

}

exam.age; // 24

Reflect.set(exam, ‘age’, 25); // true

exam.age; // 25

// value 为空时会将 name 属性清除

Reflect.set(exam, ‘age’, ); // true

exam.age; // undefined

// 当 target 对象中存在 name 属性 setter 方法时,setter 方法中的 this 会绑定 // receiver , 所以修改的实际上是 receiver 的属性,

let receiver = {

age: 18

}

Reflect.set(exam, ‘info’, 1, receiver); // true

receiver.age; // 1

let receiver1 = {

name: 'oppps'

}

Reflect.set(exam, ‘info’, 1, receiver1); //true

receiver1.age; // 1




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/111deb9571e2495dbbc4adfde4e0608b.png)  

![请添加图片描述](https://img-blog.csdnimg.cn/af305f65198b4948b970a00e160d4a49.png)



[]( )六、has 方法的使用

==============================================================================



Reflect.has(obj, name);




是 name in obj 指令的函数化,用于查找 name 属性在 obj 对象中是否存在。返回值为 boolean。如果 obj 不是对象则会报错 TypeError 。



示例代码:



let exam = {

name: "Tom",

age: 24

}

Reflect.has(exam, ‘name’); // true




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/116d4531dbd44b15b9465c9ae8d7878e.png)



[]( )七、deleteProperty 方法的使用

=========================================================================================



Reflect.deleteProperty(obj, property)




它是 `delete obj[property]` 的函数化,用于删除 obj 对象的 property 属性,返回值为 boolean。如果 obj 不是对象则会报错 TypeError。



示例代码:



let exam = {

name: "Tom",

age: 24

}

Reflect.deleteProperty(exam , ‘name’); // true

exam // {age: 24}

// property 不存在时,也会返回 true

Reflect.deleteProperty(exam , ‘name’); // true




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/44b57ac50557430aa15efb8475a41786.png)



[]( )八、construct 方法的使用

====================================================================================



Reflect.construct(obj, args)




等同于 new target(…args)。



示例代码:



function exam(name){

this.name = name;

}

Reflect.construct(exam, [‘Tom’]); // exam {name: “Tom”}




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/a3e2907bb5fe45f8b68fa946b38fe0c0.png)



[]( )九、getPrototypeOf 方法的使用

=========================================================================================



Reflect.getPrototypeOf(obj)




用于读取 obj 的 _proto_ 属性。在 obj 不是对象时不会像 Object 一样把 obj 转为对象,而是会报错。



示例代码:



class Exam{}

let obj = new Exam()

Reflect.getPrototypeOf(obj) === Exam.prototype // true




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/435c9d566f4145578593a06e30cbf45c.png)



[]( )十、setPrototypeOf 方法的使用

=========================================================================================



Reflect.setPrototypeOf(obj, newProto)




用于设置目标对象的 prototype。



示例代码:



let obj ={}

Reflect.setPrototypeOf(obj, Array.prototype); // true




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/7a60cc9f619f42aaa8cf392cdf6aeda3.png)



[]( )十一、apply 方法的使用

=================================================================================



Reflect.apply(func, thisArg, args)




等同于 `Function.prototype.apply.call(func, thisArg, args)`。func 表示目标函数;thisArg 表示目标函数绑定的 this 对象;args 表示目标函数调用时传入的参数列表,可以是数组或类似数组的对象。若目标函数无法调用,会抛出 TypeError 。



示例代码:



Reflect.apply(Math.max, Math, [1, 3, 5, 3, 1]); // 5




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/0a188966e1de453c827fe6d3a7c42af9.png)



[]( )十二、defineProperty 方法的使用

==========================================================================================



Reflect.defineProperty(target, propertyKey, attributes)




用于为目标对象定义属性。如果 target 不是对象,会抛出错误。



示例代码:



let myDate = {}

Reflect.defineProperty(myDate, ‘now’, {

value: () => Date.now()

}); // true

const student = {};

Reflect.defineProperty(student, “name”, {value: “Mike”}); // true

student.name; // “Mike”




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/eb8d58d9c52f461983c8d83410cd8cf6.png)



[]( )十三、getOwnPropertyDescriptor 方法的使用

====================================================================================================



Reflect.getOwnPropertyDescriptor(target, propertyKey)




用于得到 target 对象的 propertyKey 属性的描述对象。在 target 不是对象时,会抛出错误表示参数非法,不会将非对象转换为对象。 示例代码:



var exam = {}

Reflect.defineProperty(exam, ‘name’, {

value: true,

enumerable: false,

})

Reflect.getOwnPropertyDescriptor(exam, ‘name’)

// {value: true,writable:false, enumerable: false, configurable: false}

// propertyKey 属性在 target 对象中不存在时,返回 undefined

Reflect.getOwnPropertyDescriptor(exam, ‘age’) // undefined




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/8da6be82722e4cb6aa853d79edc6f907.png)



[]( )十四、isExtensible 方法的使用

========================================================================================



Reflect.isExtensible(target)




用于判断 target 对象是否可扩展。返回值为 boolean。如果 target 参数不是对象,会抛出错误。示例代码:



let exam = {}

Reflect.isExtensible(exam) // true




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/b1fd8f1dff8648ea8b865d7105ee21e1.png)



[]( )十五、preventExtensions 方法的使用

=============================================================================================



Reflect.preventExtensions(target)




用于让 target 对象变为不可扩展。如果 target 参数不是对象,会抛出错误。示例代码:



let exam = {}

Reflect.preventExtensions(exam) // true




在终端使用 node 命令运行:  

![请添加图片描述](https://img-blog.csdnimg.cn/c84353ff1baf454398f7927693e9a0e6.png)



[]( )十六、ownKeys 方法的使用

===================================================================================



Reflect.ownKeys(target)




用于返回 target 对象的所有属性,等同于 `Object.getOwnPropertyNames` 与 `Object.getOwnPropertySymbols` 之和。示例代码:



var exam = {

name: 1,

[Symbol.for('age')]: 4

}

Reflect.ownKeys(exam) // [“name”, Symbol(age)]

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

用于返回 target 对象的所有属性,等同于 Object.getOwnPropertyNamesObject.getOwnPropertySymbols 之和。示例代码:


var exam = {

    name: 1,

    [Symbol.for('age')]: 4

}

Reflect.ownKeys(exam) // ["name", Symbol(age)]


#  最后

**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**

**深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。**

**因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**

[外链图片转存中...(img-1DWfVTaF-1714853698654)]

[外链图片转存中...(img-3w8Z5YAO-1714853698655)]

[外链图片转存中...(img-RNHIfAAx-1714853698655)]

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**

[**如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618191877)

**由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**
  • 19
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值