JavaScript设计模式之代理模式介绍
代理模式说明
说明:顾名思义就是用一个类来代替另一个类来执行方法功能,这个模式跟装饰模式有点相似,不一样的是,代理模式是代替客户初始化被代理对象类,而装饰模式采用接口或初装饰者参数引用的方式来执行的。
在动态面向对象语言里,代理模式即起到控制修饰被代理类的作用,也对被代理类起到了充分的隐藏保护作用;被代理类只到我们需要时,才被间接初始化调用;
场景描述:
很常见到的就是租房子的例子,房客要租房子,房东要把房子租出去,但是房客跟房东都没怎么有空找房子或在家等着有人看房子,就一同去找房屋中介。房东把房间委托给中介代理租售,有合适的人需要时,中介带看房间,交钱租住,这样就帮房东把房间租出去了;房客委托房属中介帮招要求的房间位置条件,中介帮房客找到合房后,两者交钱租住,这样就替房客租到住的地方了;
实例源码
按上面的例子来实现;
1.房东出租类;
functionFangdong(){ this.room='房间名'; } Fangdong.prototype.chuzu=function(){ console.log('房东出租房间:'+this.room); }
2.中介代理类:
functionProxy(){ this.fangdong=newFangdong(); }
Proxy.prototype.chuzu=function(){ this.fangdong.chuzu(); console.log('出租后收中介费'); }