国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > 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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 城口县| 邓州市| 云浮市| 黔西县| 宣威市| 麻阳| 绥宁县| 延吉市| 秦皇岛市| 镇原县| 平安县| 张家川| 朔州市| 河北省| 晋州市| 新田县| 黄大仙区| 乌苏市| 丰都县| 邵武市| 宣武区| 海晏县| 墨玉县| 鹿邑县| 莫力| 绥江县| 云梦县| 镇康县| 承德市| 怀集县| 隆昌县| 西和县| 新竹县| 灵宝市| 仙游县| 阿克苏市| 上杭县| 旬阳县| 大石桥市| 南通市| 绿春县|