JavaScript設(shè)計(jì)模式之代理模式實(shí)例分析
本文實(shí)例講述了JavaScript設(shè)計(jì)模式之代理模式。分享給大家供大家參考,具體如下:
代理模式的定義,代理是一個(gè)對(duì)象(proxy)用它來(lái)控制目標(biāo)對(duì)象的訪問(wèn)。為此他要是先與目標(biāo)對(duì)象相同的接口,但是他不同于裝飾者模式,它對(duì)目標(biāo)對(duì)象不進(jìn)行任何修改,它的目的在于延緩"復(fù)雜"對(duì)象的初始化時(shí)間。這樣可以在用到這個(gè)目標(biāo)對(duì)象的時(shí)候再初始化他(對(duì)于單例來(lái)講更是重要)。
代理模式有兩種分類(lèi):
(1)普通代理
(2)惰性代理
具體看下面的例子
第一,普通代理模式
步驟一,接口檢驗(yàn)文件的引用
//定義一個(gè)靜態(tài)方法來(lái)實(shí)現(xiàn)接口與實(shí)現(xiàn)類(lèi)的直接檢驗(yàn)
//靜態(tài)方法不要寫(xiě)出Interface.prototype ,因?yàn)檫@是寫(xiě)到接口的原型鏈上的
//我們要把靜態(tài)的函數(shù)直接寫(xiě)到類(lèi)層次上
//定義一個(gè)接口類(lèi)
var Interface=function (name,methods) {//name:接口名字
if(arguments.length<2){
alert("必須是兩個(gè)參數(shù)")
}
this.name=name;
this.methods=[];//定義一個(gè)空數(shù)組裝載函數(shù)名
for(var i=0;i<methods.length;i++){
if(typeof methods[i]!="string"){
alert("函數(shù)名必須是字符串類(lèi)型");
}else {
this.methods.push( methods[i]);
}
}
};
Interface.ensureImplement=function (object) {
if(arguments.length<2){
throw new Error("參數(shù)必須不少于2個(gè)")
return false;
}
for(var i=1;i<arguments.length;i++){
var inter=arguments[i];
//如果是接口就必須是Interface類(lèi)型
if(inter.constructor!=Interface){
throw new Error("如果是接口類(lèi)的話,就必須是Interface類(lèi)型");
}
//判斷接口中的方法是否全部實(shí)現(xiàn)
//遍歷函數(shù)集合分析
for(var j=0;j<inter.methods.length;j++){
var method=inter.methods[j];//接口中所有函數(shù)
//object[method]傳入的函數(shù)
//最終是判斷傳入的函數(shù)是否與接口中所用函數(shù)匹配
if(!object[method]||typeof object[method]!="function" ){//實(shí)現(xiàn)類(lèi)中必須有方法名字與接口中所用方法名相同
throw new Error("實(shí)現(xiàn)類(lèi)中沒(méi)有完全實(shí)現(xiàn)接口中的所有方法")
}
}
}
}
步驟二,目標(biāo)類(lèi)
(1)圖書(shū)類(lèi)
//圖書(shū)類(lèi)
/*
* bid 圖書(shū)id
* bName 圖書(shū)名稱
* bPrice 圖書(shū)價(jià)格
* */
var Book = function(bid,bName,bPrice){
this.bid = bid;
this.bName = bName;
this.bPrice = bPrice;
}
(2)真正的目標(biāo)類(lèi)
//目標(biāo)類(lèi)
var myBookShop=(function () {
//書(shū)店里的書(shū)
var books={};
return function (bks) {
//初始化
if(typeof bks=="object"){
books=bks;
}
//加書(shū)
this.addBook = function(book){
books[book.bid] = book;
}
//找書(shū)
this.findBook=function (bid) {
if(books[bid]){
return books[bid];
}else {
return null;
}
}
//還書(shū)
this.returnBook=function (book) {
this.addBook(book);
}
//借書(shū)
this.lendBook=function (bid) {
var book=this.findBook(bid);
return book;
}
}
})();
步驟三,普通代理
var myBookShopProxy=function (bks) {
var obj=new myBookShop(bks);//類(lèi)似于目標(biāo)類(lèi)的引用
//加書(shū)
this.addBook=function (book) {
obj.addBook(book);
}
//找書(shū)
this.findBook = function(bid){
return obj.findBook(bid);
}
//還書(shū)
this.returnBook=function (book) {
obj.returnBook(book);
}
//借書(shū)
this.lendBook=function (bid) {
return obj.lendBook(bid);
}
}
步驟四,添加數(shù)據(jù)后,開(kāi)始訪問(wèn)
var proxy = new myBookShopProxy({
"001":new Book("001","EXTJS","45"),
"002":new Book("002","JS","60")
})
alert(proxy.lendBook("001").bName)
在普通的代理模式中,我們可以看出代理中對(duì)目標(biāo)對(duì)象的引用是一次性初始化的,然后再在該基礎(chǔ)上實(shí)現(xiàn)其他操作
如圖:目標(biāo)類(lèi)和代理同時(shí)實(shí)現(xiàn)了同一接口。代理中一次性對(duì)目標(biāo)類(lèi)進(jìn)行實(shí)例,然后值訪問(wèn)到目標(biāo)類(lèi)中的方法。

總結(jié),這個(gè)代理是我們嚴(yán)格安裝定義來(lái)寫(xiě)的,一般開(kāi)發(fā)中不會(huì)用到,應(yīng)為他沒(méi)什么意義。
第二種,惰性代理----在使用時(shí)才對(duì)目標(biāo)類(lèi)進(jìn)行初始化再引用。
對(duì)代理部分的修改如下,其余部分相同,代碼如下
//惰性代理---在使用時(shí)在初始化目標(biāo)類(lèi)的引用
var myBookShopProxy=function (bks) {
var obj=null;
this._init=function () {
obj=new myBookShop(bks);
}
//加書(shū)
this.addBook=function (book) {
this._init();
obj.addBook(book);
}
//找書(shū)
this.findBook=function (bid) {
this._init();
obj.findBook(bid);
}
//還書(shū)
this.returnBook=function (book) {
this._init();
obj.returnBook(book);
}
//借書(shū)
this.lendBook=function (bid) {
this._init();
return obj.lendBook(bid);
}
}
修改后的代理執(zhí)行過(guò)程,如圖

更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專題:《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
ReactHooks+ts(函數(shù)組件)實(shí)現(xiàn)原生輪播的示例
這篇文章主要介紹了ReactHooks+ts函數(shù)組件實(shí)現(xiàn)原生輪播,在這里下載依賴第一個(gè)是js依賴第二個(gè)是ts依賴,通過(guò)實(shí)例代碼介紹了創(chuàng)建tsx文件的方法,需要的朋友可以參考下2022-05-05
JavaScript組合拼接字符串的效率對(duì)比測(cè)試
這篇文章主要介紹了JavaScript組合拼接字符串的效率對(duì)比測(cè)試,本文測(cè)試了IE6、Firefox、Mozilla、Netscape、Opera等瀏覽器,需要的朋友可以參考下2014-11-11
JavaScript實(shí)現(xiàn)圖片偽異步上傳過(guò)程解析
這篇文章主要介紹了javascript實(shí)現(xiàn)圖片偽異步上傳過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04

