ES6 proxy和reflect的使用方法与应用实例分析
本文实例讲述了ES6proxy和reflect的使用方法。分享给大家供大家参考,具体如下:
proxy和reflect都是es6为了更好的操作对象而提供的新的API,接下来探讨一下二者的作用,联系。
设计proxy,reflect的作用:
proxy的作用:
Proxy的设计目的在于(修改编程语言),修改某些操作方法的默认行为,
等同于在语言层面作出修改,是元编程(metaprogramming) 例如修改set,get方法
reflect的作用:
1,映射一些明显属于对象语言内部的方法,目前是共存于Object和Reflect上,未来只在Reflect上
2,修改一些Object上的方法返回的结果,减少异常抛出,使其变得更加合理
3,让Object操作都变成函数行为(主要的作用)
4,Reflect对象的方法与Proxy对象的方法一一对应(主要的作用)
proxy和reflect的方法:
proxy的实例方法:
varperson={ name:"张三" }; varproxy=newProxy(person,{ get:function(target,property){ if(propertyintarget){ returntarget[property]; }else{ thrownewReferenceError("Property\""+property+"\"doesnotexist."); } } });
注:目标对象内部的this关键字会指向Proxy代理
自身方法:Proxy.revocable方法返回一个可取消的Proxy实例
reflect的静态方法:
和proxy相对应,reflect有13个静态方法,分别一一对应于proxy的实例方法
proxy和reflect联系:proxy的实例方法和reflect的静态方法一一对应
实例:观察者模式的实现
constqueuedObservers=newSet(); constobserve=fn=>queuedObservers.add(fn);//接收一个函数fn constobservable=obj=>newProxy(obj,{set});//接收一个对象obj,采用set函数拦截设置obj functionset(target,key,value,receiver){ constresult=Reflect.set(target,key,value,receiver); queuedObservers.forEach(observer=>observer()); returnresult; }
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于JavaScript相关内容可查看本站专题:《JavaScript操作DOM技巧总结》、《JavaScript页面元素操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。