ES6知识点整理之Proxy的应用实例详解
本文实例讲述了ES6知识点整理之Proxy的应用。分享给大家供大家参考,具体如下:
Proxy用于修改对象某些操作的默认行为,可以对外界的访问进行过滤和改写,其概念类似于元编程。
Proxy让我们可以对任何对象的绝大部分行为进行监听和干涉,实现更多的自定义程序行为。在目标对象之前架设一层“拦截”,外界对该对象的访问,都必须先通过这层拦截。
目前【兼容性】存在一定的问题,目前在chrome和ff浏览器中的非严格模式下可用,一些先进的技术即使在目前不能广泛应用,但随着时间的流逝,都将会进入程序员日常的编程中。
注:博客整理时间:2018-03-2416:21:15
初识Proxy
varobj={name:'Joh'}; varproxy=newProxy(obj,{ get(target,key){ return'test1'; }, set(target,key,value){ target[key]=value } }); console.log(proxy.name);//test1进行get取值 proxy.name='test2';//进行set设置 console.log(obj.name);//test2
通过Proxy对象进行拦截target对象的属性
完整的使用Proxy进行设置,获取,修改和删除的案例
varobj={name:'Joh',group:'g1',_type:'student'}; varproxy=newProxy(obj,{ get(target,key){ if(key[0]!=='_'){ //returnReflect.get(target,key);//效果等同于下面的return语句 returntarget[key]; }; }, set(target,key,value){ if(key[0]!=='_'){ //Reflect.set(target,key,value); returntarget[key]=value; } }, deleteProperty(target,key){ //业务逻辑 if(key[0]!=='_'){ //Reflect.deleteProperty(target,key); deletetarget[key]; } } }); console.log(proxy.name);//Joh console.log(obj.name);//Joh proxy.name='Lily';//在非严格模式下的赋值操作,严格模式将会报错 console.log(obj.name);//Lily deleteproxy.name;//未能成功删除,因为上面内部有判断 console.log(obj.name);//undefined成功删除 deleteproxy.group; console.log(obj.group);//undefined成功删除 deleteproxy._type; console.log(obj._type);//student proxy.color='red'; console.log(obj.color);//red
其中借助Reflect实现和直接实现的效果等同
通过has方法和in关键字进行拦截的示例:
varobj={name:"Joh",_name:"Lily"}; varproxy=newProxy(obj,{ has(target,key){ if(key[0]==='_'){ returnfalse; }else{ returnkeyintarget; } } }); console.log('hasnameattr:','name'inproxy);//hasnameattr:true console.log('has_nameattr:','_name'inproxy);//has_nameattr:false
使用ownKeys方法与for-in遍历过滤符合特定规则属性的示例
varobj={name:"Joh",_name:"Lily",age:10,group:"g1"}; varproxy=newProxy(obj,{ ownKeys(target){ returnReflect.ownKeys(target).filter(key=>key[0]!=='_'); } }); for(varkinproxy){ console.log(k);//分别输出nameagegroup过滤了_name }
通过apply方法对函数调用的拦截
functiontest(){ console.log('helloworld'); } varproxyFun=newProxy(test,{ apply(target,ctx,args){ console.log('proxyapply'); returnReflect.apply(target,ctx,args); } }); proxyFun();//分别输出proxyapply和helloworld //proxyFun.apply();//同样,分别输出proxyapply和helloworld //proxyFun.call();//同样,分别输出proxyapply和helloworld
通过construct方法对构造函数实例化的拦截
functionUser(){ console.log('thisisacontructor'); } varClassProxy=newProxy(User,{ construct(target,args){ console.log('proxyconstruct'); returnReflect.construct(target,args); } }); newClassProxy();//分别输出proxyconstruct和thisisacontructor
更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。