ES6的Proxy
Posted tangjiao
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6的Proxy相关的知识,希望对你有一定的参考价值。
最近在javascript的设计编程中,用到的那个单例模式,感觉就类似一种代理的思想,单例模式就是:
function getSingle(fn){ var result; return function(){ return result || (result = fn.apply(this,arguments)); } }
任何在getSingle传入方法的函数,都会具有单例模式,就类似于代理的思想,函数的执行得先过getSingle,它里面有个result的缓存,有缓存返回缓存,但是跟ES6的Proxy还是有点区别。
var proxy = new Proxy(target, handler);
target是代理的对象,handler是参数,也是一个对象,定制拦截行为。
var proxy = new Proxy({}, { get: function(target, property) { return 35; } }); let obj = Object.create(proxy); obj.time // 35
看这段代码:obj直接原型继承了代理对象proxy,那么访问obj的属性时,如果自身没有属性,就会访问原型链。
Proxy代理的用处很多,方法get,set,apply,has,construct等方法,多看些大神的用法,后面慢慢孰能生巧吧,知道这个东西是干嘛的,以后怎么用还得实际项目或者练习中进行巩固啦。
【完】
让我们攀上高峰的不是奇招,而是熟能生巧的基本功。能成为顶尖高手并没有什么秘诀,而是对基本技能的东西有更深的理解。每天都要学得更深一点而不是更广一点,因为学得更深可以让我们把潜力中哪些看不到、感受不到但又极具创造力的部分挖掘出来。
——乔希·维茨金 《学习之道》
以上是关于ES6的Proxy的主要内容,如果未能解决你的问题,请参考以下文章