JavaScript設(shè)計(jì)模式之代理模式介紹
代理模式說明
說明:顧名思義就是用一個(gè)類來代替另一個(gè)類來執(zhí)行方法功能,這個(gè)模式跟裝飾模式有點(diǎn)相似,不一樣的是,代理模式是代替客戶初始化被代理對(duì)象類,而裝飾模式采用接口或初裝飾者參數(shù)引用的方式來執(zhí)行的。
在動(dòng)態(tài)面向?qū)ο笳Z言里,代理模式即起到控制修飾被代理類的作用,也對(duì)被代理類起到了充分的隱藏保護(hù)作用;被代理類只到我們需要時(shí),才被間接初始化調(diào)用;
場(chǎng)景描述:
很常見到的就是租房子的例子,房客要租房子,房東要把房子租出去,但是房客跟房東都沒怎么有空找房子或在家等著有人看房子,就一同去找房屋中介。房東把房間委托給中介代理租售,有合適的人需要時(shí),中介帶看房間,交錢租住,這樣就幫房東把房間租出去了;房客委托房屬中介幫招要求的房間位置條件,中介幫房客找到合房后,兩者交錢租住,這樣就替房客租到住的地方了;
實(shí)例源碼
按上面的例子來實(shí)現(xiàn);
1. 房東出租類;
function Fangdong() {
this.room = '房間名';
}
Fangdong.prototype.chuzu = function() {
console.log('房東出租房間: ' + this.room);
}
2. 中介代理類:
function Proxy() {
this.fangdong = new Fangdong();
}
Proxy.prototype.chuzu = function() {
this.fangdong.chuzu();
console.log('出租后收中介費(fèi)');
}
3. 使用方法:
//房客請(qǐng)中介幫找房子;
var proxy = new Proxy();
proxy.chuzu();
看看上面的使用,被代理類在客戶端完全用不著,只要使用Proxy類即可,可以很好使用在那種需要保護(hù)某些業(yè)務(wù)邏輯過程的情景中;使用代理模式,可以很好的保護(hù)需要保護(hù)的被代理類;
其他說明
跟裝飾者模式一樣,代理模式也很好的體現(xiàn)了面向?qū)ο笏枷氲膶?duì)擴(kuò)展開放,對(duì)修改關(guān)閉的原則;
代理模式,可以使用接口或抽象類來規(guī)范共同的接口:(以下提供JAVA方式代理模式)
1. 抽象類 abstract 方式;
public abstract class House {
public void abstract chuzu();
}
public class Fangdong extends House {
private String room = “房間名稱”;
@Override
public void chuzu() {
System.out.println(room);
}
}
public class Proxy extends House {
private Fangdong fangdong;
public Proxy() {
this.fangdong = new Hangdong();
}
@Override
public void chuzu() {
this.fandong.chuzu();
System.out.println(“出租后交中介費(fèi)”);
}
}
//使用
House house = new Proxy();
house.chuzu();
2. 接口 Interface 方式:
interface House {
public void chuzu();
}
public class Fangdong implements House {
private String room = “房間名稱”;
@Override
public void chuzu() {
System.out.println(room);
}
}
public class Proxy implements House {
private Fangdong fangdong;
public Proxy() {
this.fangdong = new Hangdong();
}
@Override
public void chuzu() {
this.fandong.chuzu();
System.out.println(“出租后交中介費(fèi)”);
}
}
//使用
House house = new Proxy();
house.chuzu();
- javascript設(shè)計(jì)模式 – 代理模式原理與用法實(shí)例分析
- js設(shè)計(jì)模式之代理模式及訂閱發(fā)布模式實(shí)例詳解
- 詳解javascript設(shè)計(jì)模式三:代理模式
- JavaScript設(shè)計(jì)模式之代理模式實(shí)例分析
- JavaScript設(shè)計(jì)模式之緩存代理模式原理與簡單用法示例
- JavaScript設(shè)計(jì)模式之代理模式簡單實(shí)例教程
- JavaScript設(shè)計(jì)模式之代理模式詳解
- JavaScript的設(shè)計(jì)模式經(jīng)典之代理模式
- 學(xué)習(xí)JavaScript設(shè)計(jì)模式之代理模式
- 學(xué)習(xí)JavaScript設(shè)計(jì)模式(代理模式)
- 深入理解JavaScript系列(31):設(shè)計(jì)模式之代理模式詳解
- JavaScript設(shè)計(jì)模式學(xué)習(xí)之代理模式
相關(guān)文章
基于JavaScript實(shí)現(xiàn)線性漸變的高斯模糊效果
這篇文章主要為大家詳細(xì)介紹了高斯模糊算法以及線性漸變的高斯模糊算法的原理,并通過一個(gè)小demo展示了如何實(shí)現(xiàn)y方向上線性漸變的高斯模糊效果,需要的可以了解下2024-01-01
詳解在IDEA中將Echarts引入web兩種方式(使用js文件和maven的依賴導(dǎo)入)
這篇文章主要介紹了在IDEA中將Echarts引入web兩種方式(使用js文件和maven的依賴導(dǎo)入),本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
Node.js:Windows7下搭建的Node.js服務(wù)(來玩玩服務(wù)器端的javascript吧,這可不是前端js插件
什么是Node.js?還服務(wù)器端javascript?對(duì)于這個(gè)概念我在這篇文章不做解釋,可以自己去搜索了解下,服務(wù)器端js不是新技術(shù),只是最近的node.js的火爆讓他爆發(fā)了,我會(huì)在以后的文章里解釋什么是node.js。2011-06-06
詳解JavaScript如何實(shí)現(xiàn)更短時(shí)間的延時(shí)函數(shù)
在項(xiàng)目開發(fā)中,經(jīng)常能遇到需要延時(shí)執(zhí)行的需求,比如實(shí)現(xiàn)一個(gè)定時(shí)器功能,本文主要和大家介紹了JS如何實(shí)現(xiàn)更短時(shí)間的延時(shí)函數(shù),需要的可以參考下2024-03-03
BootStrap點(diǎn)擊下拉菜單項(xiàng)后顯示一個(gè)新的輸入框?qū)崿F(xiàn)代碼
這篇文章主要介紹了BootStrap點(diǎn)擊下拉菜單項(xiàng)后顯示一個(gè)新的輸入框?qū)崿F(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2016-05-05
javascript實(shí)現(xiàn)的使用方向鍵控制光標(biāo)在table單元格中切換
最近公司開發(fā)ERP項(xiàng)目,要求商品入庫選擇貨架號(hào)時(shí)支持使用方向鍵快速選擇,以提高入庫效率。2010-11-11

