日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript代理模式原理與用法實例詳解

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

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

代理模式的定義,代理是一個對象(proxy)用它來控制目標對象的訪問。為此他要是先與目標對象相同的接口,但是他不同于裝飾者模式,它對目標對象不進行任何修改,它的目的在于延緩'復雜'對象的初始化時間。這樣可以在用到這個目標對象的時候再初始化他(對于單例來講更是重要)。

代理模式有兩種分類:

(1)普通代理

(2)惰性代理

具體看下面的例子

第一,普通代理模式

步驟一,接口檢驗文件的引用

//定義一個靜態方法來實現接口與實現類的直接檢驗//靜態方法不要寫出Interface.prototype ,因為這是寫到接口的原型鏈上的//我們要把靜態的函數直接寫到類層次上//定義一個接口類var Interface=function (name,methods) {//name:接口名字 if(arguments.length<2){ alert('必須是兩個參數') } this.name=name; this.methods=[];//定義一個空數組裝載函數名 for(var i=0;i<methods.length;i++){ if(typeof methods[i]!='string'){ alert('函數名必須是字符串類型'); }else { this.methods.push( methods[i]); } }};Interface.ensureImplement=function (object) { if(arguments.length<2){ throw new Error('參數必須不少于2個') return false; } for(var i=1;i<arguments.length;i++){ var inter=arguments[i]; //如果是接口就必須是Interface類型 if(inter.constructor!=Interface){ throw new Error('如果是接口類的話,就必須是Interface類型'); } //判斷接口中的方法是否全部實現 //遍歷函數集合分析 for(var j=0;j<inter.methods.length;j++){ var method=inter.methods[j];//接口中所有函數 //object[method]傳入的函數 //最終是判斷傳入的函數是否與接口中所用函數匹配 if(!object[method]||typeof object[method]!='function' ){//實現類中必須有方法名字與接口中所用方法名相同throw new Error('實現類中沒有完全實現接口中的所有方法') } } }}

步驟二,目標類

(1)圖書類

//圖書類 /* * bid 圖書id * bName 圖書名稱 * bPrice 圖書價格 * */ var Book = function(bid,bName,bPrice){ this.bid = bid; this.bName = bName; this.bPrice = bPrice; }

(2)真正的目標類

//目標類 var myBookShop=(function () { //書店里的書 var books={}; return function (bks) { //初始化 if(typeof bks=='object'){ books=bks; } //加書 this.addBook = function(book){ books[book.bid] = book; } //找書 this.findBook=function (bid) { if(books[bid]){ return books[bid]; }else { return null; } } //還書 this.returnBook=function (book) {this.addBook(book); } //借書 this.lendBook=function (bid) {var book=this.findBook(bid);return book; } } })();

步驟三,普通代理

var myBookShopProxy=function (bks) { var obj=new myBookShop(bks);//類似于目標類的引用 //加書 this.addBook=function (book) { obj.addBook(book); } //找書 this.findBook = function(bid){ return obj.findBook(bid); } //還書this.returnBook=function (book) { obj.returnBook(book);} //借書 this.lendBook=function (bid) { return obj.lendBook(bid); } }

步驟四,添加數據后,開始訪問

var proxy = new myBookShopProxy({ '001':new Book('001','EXTJS','45'), '002':new Book('002','JS','60') }) alert(proxy.lendBook('001').bName)

在普通的代理模式中,我們可以看出代理中對目標對象的引用是一次性初始化的,然后再在該基礎上實現其他操作

如圖:目標類和代理同時實現了同一接口。代理中一次性對目標類進行實例,然后值訪問到目標類中的方法。

JavaScript代理模式原理與用法實例詳解

總結,這個代理是我們嚴格安裝定義來寫的,一般開發中不會用到,應為他沒什么意義。

第二種,惰性代理----在使用時才對目標類進行初始化再引用。

對代理部分的修改如下,其余部分相同,代碼如下

//惰性代理---在使用時在初始化目標類的引用 var myBookShopProxy=function (bks) { var obj=null; this._init=function () { obj=new myBookShop(bks); } //加書 this.addBook=function (book) { this._init(); obj.addBook(book); } //找書 this.findBook=function (bid) { this._init(); obj.findBook(bid); } //還書 this.returnBook=function (book) { this._init(); obj.returnBook(book); } //借書 this.lendBook=function (bid) { this._init(); return obj.lendBook(bid); } }

修改后的代理執行過程,如圖

JavaScript代理模式原理與用法實例詳解

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

更多關于JavaScript相關內容還可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女毛片一区二区三区四区最新中文字幕亚洲| 婷婷精品在线| 久草精品视频| 国产精品伦理久久久久久| 日韩1区2区3区| 97成人超碰| 日韩高清欧美激情| 国产劲爆久久| 亚洲成av在线| 视频一区中文字幕| 91成人精品观看| 黄色aa久久| 日韩在线观看一区二区| 一区二区三区四区精品视频| 99精品美女| 中文字幕亚洲在线观看| 在线观看一区| 国产精品videossex久久发布| 亚洲精品在线国产| 麻豆视频久久| 尤物网精品视频| 亚洲久久一区| 黄色精品视频| 久久亚洲精品伦理| 美女久久精品| 国产一区日韩欧美| 日本aⅴ精品一区二区三区| 蜜桃av一区二区在线观看| 免费在线视频一区| 美腿丝袜在线亚洲一区| 久久精品一区二区国产| 麻豆视频在线观看免费网站黄| 欧美性www| 国产精品啊v在线| 国产精品蜜芽在线观看| 亚洲一级二级| 伊人久久亚洲美女图片| 日韩av网站在线免费观看| 日韩欧美三区| 欧产日产国产精品视频| 午夜欧美巨大性欧美巨大| 国产66精品| 亚洲午夜免费| 国产精品17p| 亚洲精品成人| 亚洲精品极品| 亚洲大片在线| 亚洲人亚洲人色久| 免费在线亚洲| 亚洲va中文在线播放免费| 久久久久九九精品影院| 亚洲天堂av影院| 99国产精品自拍| 日韩高清中文字幕一区二区| 中国字幕a在线看韩国电影| 久久亚洲精品伦理| 国产精品magnet| 国产在线看片免费视频在线观看| 蜜桃伊人久久| 欧美黑人做爰爽爽爽| 91久久久精品国产| 91嫩草精品| 国产亚洲福利| 麻豆极品一区二区三区| 久久视频一区| 欧美有码在线| 国产综合亚洲精品一区二| 欧美精品国产一区| 91精品在线观看国产| 国产欧美一区二区三区国产幕精品| 国产传媒在线观看| 国产精品男女| 夜夜精品视频| av成人国产| 日韩精品专区| 成人片免费看| 日韩精品1区2区3区| 日本欧美不卡| 亚洲激情二区| 国产日韩电影| 国产精品网在线观看| 超碰成人av| 欧美激情综合| 亚洲ww精品| 日本一区二区三区视频在线看| 国产成人精选| 成人三级高清视频在线看| 亚洲tv在线| 国产自产自拍视频在线观看| 日本电影久久久| 欧美成人午夜| 欧美理论视频| 欧美二三四区| 久久久久中文| 高清不卡亚洲| 久久精品高清| 久久精品九色| 精品久久久中文字幕| 免费在线视频一区| 91精品韩国| 国内亚洲精品| 日韩欧美中文| 久久精品国产亚洲夜色av网站| 国产欧美啪啪| 国产精品毛片久久久| 蜜桃av一区| 中文字幕乱码亚洲无线精品一区| 日韩在线观看不卡| 黄色精品网站| 99国产精品99久久久久久粉嫩| 国产综合精品| 久久国产欧美| 中文字幕成在线观看| 伊伊综合在线| 久久久久久网| 激情综合网五月| 欧美特黄视频| 日韩精品成人| 国产日韩欧美三级| 久久青青视频| 婷婷精品视频| 视频一区日韩精品| 日韩视频1区| 精品伊人久久| 天堂а√在线最新版中文在线| 久久精品123| 精品免费视频| 欧美日韩在线播放视频| 国产精品网站在线看| 青草国产精品| 国产不卡精品在线| 蜜桃久久精品一区二区| 久久亚洲黄色| 精品国产91| 国产精品专区免费| 综合在线一区| 国产在线观看www| 国产一区二区三区黄网站| 国产精品免费看| 久久国产免费看| 色爱综合网欧美| 黄毛片在线观看| 国产精品久久久久久久久妇女| 日本少妇一区二区| 日本午夜免费一区二区 | 久久字幕精品一区| 日韩高清国产一区在线| 欧美性感美女一区二区 | 日韩精品社区| 欧美二区视频| 免费成人在线观看| 国产精品久久免费视频| 国产精品99久久免费观看| 综合国产精品| 国产精品亚洲欧美日韩一区在线| 国产成人精品免费视| 成人在线超碰| 亚洲网址在线观看| 你懂的国产精品| 蜜桃一区二区三区在线| 91麻豆精品激情在线观看最新 | 99精品国产一区二区三区| 久久影视一区| 青青伊人久久| 日韩午夜一区| 国产精久久一区二区| 91综合网人人| 久久亚洲图片| 久久国产直播| 人人爱人人干婷婷丁香亚洲| 国产精品成人一区二区网站软件| 欧美日韩一区二区三区不卡视频| 四虎884aa成人精品最新| 午夜国产欧美理论在线播放| 日韩一区精品| 成人精品国产亚洲| 亚洲专区一区| 国产精品毛片久久| 奇米色欧美一区二区三区| 大香伊人久久精品一区二区| 亚洲精品人人| 高潮一区二区| 日本aⅴ精品一区二区三区| 亚洲婷婷免费| 日韩av中文字幕一区二区| 久久一级电影| 国产精品资源| 欧美日韩1区| 欧美美女一区| 人人精品亚洲| 国产欧美综合一区二区三区| 久久激情中文| 国产日韩亚洲| 欧美午夜三级| 日韩视频免费| 欧美在线亚洲| 高清一区二区| 久久久久久久欧美精品| 91九色精品国产一区二区| 精品国产一区二区三区噜噜噜|