时间:2021-05-28
本文实例讲述了ES6 proxy和reflect的使用方法。分享给大家供大家参考,具体如下:
proxy和reflect都是es6为了更好的操作对象而提供的新的API,接下来探讨一下二者的作用,联系。
设计proxy,reflect的作用:
proxy的作用:
Proxy的设计目的在于(修改编程语言),修改某些操作方法的默认行为,
等同于在语言层面作出修改,是元编程(meta programming)例如修改set,get方法
reflect的作用:
1,映射一些明显属于对象语言内部的方法,目前是共存于Object和Reflect上,未来只在Reflect上
2,修改一些Object上的方法返回的结果,减少异常抛出,使其变得更加合理
3,让Object操作都变成函数行为(主要的作用)
4,Reflect对象的方法与Proxy对象的方法一一对应(主要的作用)
proxy和reflect的方法:
proxy的实例方法:
get()set()apply()has()cunstruct()deleteProperty()defineProperty()getOwnPropertyDescriptor()getPrototypeOf()isExtensible()ownKeys(),preventExtensions()setPrototypeOf() var person = { name: "张三"}; var proxy = new Proxy(person, { get: function(target, property) { if (property in target) { return target[property]; } else { throw new ReferenceError("Property \"" + property + "\" does not exist."); } }});注:目标对象内部的this关键字会指向 Proxy 代理
自身方法:Proxy.revocable方法返回一个可取消的 Proxy 实例
reflect的静态方法:
和proxy相对应,reflect有13个静态方法,分别一一对应于proxy的实例方法
Reflect.apply(target, thisArg, args)Reflect.construct(target, args)Reflect.get(target, name, receiver)Reflect.set(target, name, value, receiver)Reflect.defineProperty(target, name, desc)Reflect.deleteProperty(target, name)Reflect.has(target, name)Reflect.ownKeys(target)Reflect.isExtensible(target)Reflect.preventExtensions(target)Reflect.getOwnPropertyDescriptor(target, name)Reflect.getPrototypeOf(target)Reflect.setPrototypeOf(target, prototype)实例:观察者模式的实现
const queuedObservers = new Set(); const observe = fn => queuedObservers.add(fn);//接收一个函数fnconst observable = obj => new Proxy(obj, {set});//接收一个对象obj,采用set函数拦截设置obj function set(target, key, value, receiver) { const result = Reflect.set(target, key, value, receiver); queuedObservers.forEach(observer => observer()); return result;}感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容可查看本站专题:《JavaScript操作DOM技巧总结》、《JavaScript页面元素操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了ES6中Proxy与Reflect实现重载(overload)的方法。分享给大家供大家参考,具体如下:Proxy与Reflect实现重载(over
概述Proxy与Reflect是ES6为了操作对象引入的API。Proxy可以对目标对象的读取、函数调用等操作进行拦截,然后进行操作处理。它不直接操作对象,而是
本文实例讲述了es6中let和const的使用方法。分享给大家供大家参考,具体如下:ES6新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量
本文实例讲述了es6中class类静态方法,静态属性,实例属性,实例方法。分享给大家供大家参考,具体如下:es6新增了一种定义对象实例的方法,使用class关键
Proxy是在ES2015(ES6)中新添加内置对象,用于自定义一些基本操作。这篇文章是我在学习Proxy的时候对于get方法的一些心得。作为ES2015新定义