色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript代理模式原理與用法實(shí)例詳解

瀏覽:113日期:2023-11-07 15:28:40

本文實(shí)例講述了JavaScript代理模式原理與用法。分享給大家供大家參考,具體如下:

代理模式的定義,代理是一個(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ū)名稱(chēng) * 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)中的方法。

JavaScript代理模式原理與用法實(shí)例詳解

總結(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ò)程,如圖

JavaScript代理模式原理與用法實(shí)例詳解

感興趣的朋友可以使用在線HTML/CSS/JavaScript前端代碼調(diào)試運(yùn)行工具:http://tools.jb51.net/code/WebCodeRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專(zhuān)題:《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ì)有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 黄色成人在线网站 | 欧美在线高清视频播放免费 | 韩国美女爽快一毛片免费 | 三级视频欧美 | 国产日韩精品欧美一区视频 | 欧美日本高清视频在线观看 | 欧洲成人免费视频 | 91精品欧美一区二区三区 | 欧美三级一区二区 | 亚洲午夜在线 | 天天爱天天做天天爽天天躁 | 久久黄网 | 国产精品18久久久久久小说 | 一级毛片免费完整视频 | 一级片免费网址 | 一级毛片在线播放 | 在线观看一级毛片免费 | 亚洲人成毛片线播放 | 一级欧美一级日韩 | 国产精品九九视频 | 国产欧美在线观看视频 | 亚洲精品国产成人专区 | 天堂精品高清1区2区3区 | 欧美一级带 | 亚洲人成在线播放网站 | 一本一本久久a久久精品综合麻豆 | 久久久www成人免费精品 | 成人18免费网| 波多野结衣视频免费 | 五月激激激综合网色播免费 | 国产乱子伦露脸对白在线小说 | 日韩欧国产精品一区综合无码 | 日本特黄特色大片免费视频网站 | 国内精品久久精品 | 99精品视频免费在线观看 | 国内成人免费视频 | 国产日韩久久久精品影院首页 | 91精品一区二区三区在线 | 欧美18在线 | 九九九九在线精品免费视频 | 日韩亚洲欧美在线 |