亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript設計模式之代理模式實例分析

2019-11-19 12:17:06
字體:
來源:轉載
供稿:網友

本文實例講述了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)

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

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

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

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

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

//惰性代理---在使用時在初始化目標類的引用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相關內容還可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日本精品在线| 中文字幕日本精品| 国产99在线|中文| 亚洲最大成人免费视频| 欧美精品18videos性欧| 欧美一区三区三区高中清蜜桃| 91九色精品视频| 国产一区二区激情| 色妞在线综合亚洲欧美| 国产成人激情小视频| 亚洲一区二区三区视频播放| 亚洲xxxx在线| 亚洲丝袜av一区| 在线电影av不卡网址| 精品亚洲一区二区三区四区五区| 成人久久久久久久| 日韩三级影视基地| 欧美视频中文在线看| 成人激情在线播放| 日韩精品在线免费观看视频| 日韩精品在线视频| 中文字幕成人在线| 久久av中文字幕| 国产男女猛烈无遮挡91| 国自产精品手机在线观看视频| 欧美日韩成人在线观看| 成人亚洲欧美一区二区三区| 国产91精品久久久久久| 久久久国产精品一区| 亚洲激情免费观看| 亚洲最大在线视频| 日韩成人在线视频网站| 欧洲精品毛片网站| 亚洲一区二区三区成人在线视频精品| 国产精品福利小视频| 亚洲天堂男人天堂| 成人444kkkk在线观看| 日韩精品在线播放| 亚洲激情自拍图| 国产91色在线|免| 亚洲电影免费在线观看| 国产中文字幕日韩| www.午夜精品| www.亚洲一区| 欧美在线视频播放| 亚洲男人天堂九九视频| 久久久精品久久| 国产一区二中文字幕在线看| 久久久999成人| 性色av一区二区三区在线观看| 久久久久国产精品www| 精品视频在线播放| 久久综合免费视频| 97国产在线观看| 欧美精品免费在线| 欧美一级大片视频| 国产日韩欧美成人| 色黄久久久久久| 国产亚洲视频在线| 国产视频自拍一区| 亚洲欧洲激情在线| 亚洲精品视频久久| 亚洲电影第1页| 亚洲视频精品在线| 欧美亚洲第一页| 亚洲欧美国产精品专区久久| 亚洲国产欧美一区二区三区同亚洲| 国产欧美精品日韩精品| 日韩成人在线视频网站| 亚洲精品中文字幕女同| 国产+成+人+亚洲欧洲| 欧美专区中文字幕| 欧美黑人极品猛少妇色xxxxx| 久久视频免费观看| 中文字幕在线成人| 精品欧美国产一区二区三区| 色琪琪综合男人的天堂aⅴ视频| 精品性高朝久久久久久久| 国产精品视频大全| 亚洲精品福利免费在线观看| 日本国产一区二区三区| 91精品国产色综合久久不卡98| 国产午夜精品理论片a级探花| www.日本久久久久com.| 欧美激情一区二区三区成人| 一区二区三区日韩在线| 日韩中文字幕在线播放| 在线成人激情视频| 国产日韩欧美视频在线| 成人精品一区二区三区电影黑人| 久久久成人精品| 国模极品一区二区三区| 国产亚洲激情视频在线| 亚洲电影免费观看高清完整版在线观看| 精品av在线播放| 国产精品影片在线观看| 黄色一区二区在线| 中文字幕久热精品视频在线| 91九色国产视频| 91香蕉嫩草影院入口| 亚洲一级黄色av| 久久久久久91香蕉国产| 日韩中文第一页| 午夜精品福利视频| 国产一区二区日韩精品欧美精品| 日韩中文字幕不卡视频| 日韩av高清不卡| 久久99久久久久久久噜噜| 日韩三级影视基地| 欧美日韩国产91| 亚洲国产欧美一区二区丝袜黑人| 久久好看免费视频| 97精品在线视频| 亚洲福利视频网站| 91久久久久久久久久久久久| 91影院在线免费观看视频| 九色精品免费永久在线| 国产精品一香蕉国产线看观看| 日韩一区二区精品视频| 精品一区二区三区四区在线| 综合国产在线观看| 欧美大尺度电影在线观看| 91久久精品国产91久久| 久久久精品久久久久| 国产成人自拍视频在线观看| 欧美最猛性xxxxx(亚洲精品)| 91国产精品视频在线| 亚洲一品av免费观看| 国产精品美女久久久久av超清| 久久精品一区中文字幕| 青草青草久热精品视频在线网站| 成人免费视频在线观看超级碰| 91九色国产社区在线观看| 欧美精品video| 欧美极品欧美精品欧美视频| 国语自产精品视频在线看抢先版图片| 久久成人精品电影| 亚洲国产私拍精品国模在线观看| 欧美日韩亚洲一区二区三区| 久久精品这里热有精品| 97在线视频观看| 91影视免费在线观看| 色综合天天综合网国产成人网| 在线色欧美三级视频| 91国产精品视频在线| 亚洲欧美在线免费观看| 国产丝袜视频一区| 成人国内精品久久久久一区| 三级精品视频久久久久| 色妞在线综合亚洲欧美| 日韩a**中文字幕| 91色视频在线观看| 国产专区欧美专区| 日韩精品亚洲元码| 日韩动漫免费观看电视剧高清| 福利视频导航一区| 亚洲精品日韩欧美| 成人精品一区二区三区电影免费| 国产精品久久久久久av| 青青草国产精品一区二区| 国产精品夜色7777狼人| 美女性感视频久久久| 成人免费在线视频网站| 欧美综合国产精品久久丁香|