欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年03月10日 09:59:25   作者:WFaceBoss  
這篇文章主要介紹了JavaScript代理模式原理與用法,結(jié)合實例形式詳細(xì)分析了JavaScript代理模式基本概念、原理、用法與操作注意事項,需要的朋友可以參考下

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

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

代理模式有兩種分類:

(1)普通代理

(2)惰性代理

具體看下面的例子

第一,普通代理模式

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

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

步驟二,目標(biāo)類

(1)圖書類

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

(2)真正的目標(biāo)類

 //目標(biāo)類
  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);//類似于目標(biāo)類的引用
     //加書
    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);
    }
  }

步驟四,添加數(shù)據(jù)后,開始訪問

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

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

如圖:目標(biāo)類和代理同時實現(xiàn)了同一接口。代理中一次性對目標(biāo)類進(jìn)行實例,然后值訪問到目標(biāo)類中的方法。

總結(jié),這個代理是我們嚴(yán)格安裝定義來寫的,一般開發(fā)中不會用到,應(yīng)為他沒什么意義。

第二種,惰性代理----在使用時才對目標(biāo)類進(jìn)行初始化再引用。

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

 //惰性代理---在使用時在初始化目標(biāo)類的引用
  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);
    }
  }

修改后的代理執(zhí)行過程,如圖

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

更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

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

相關(guān)文章

  • JS實現(xiàn)同時搜索百度和必應(yīng)的方法

    JS實現(xiàn)同時搜索百度和必應(yīng)的方法

    這篇文章主要介紹了JS實現(xiàn)同時搜索百度和必應(yīng)的方法,可實現(xiàn)在底部的兩個框架中同時顯示兩個搜索引擎的搜索結(jié)果,是非常實用的技巧,需要的朋友可以參考下
    2015-01-01
  • js淡入淡出焦點圖幻燈片效果代碼分享

    js淡入淡出焦點圖幻燈片效果代碼分享

    這篇文章主要介紹了js淡入淡出焦點圖幻燈片效果,圖片輪播效果特別適合做產(chǎn)品展示,自己可以更改圖片,標(biāo)題,感興趣的小伙伴可以參考下。
    2015-09-09
  • javascript函數(shù)式編程程序員的工具集

    javascript函數(shù)式編程程序員的工具集

    函數(shù)式編程語言一向被認(rèn)為是比其它編程語言更高深的語言。一是因為函數(shù)式編程語言的語法很另類,比如Lisp語言,二是因為函數(shù)式編程語言都很古老,比如Schema語言。在如今面向?qū)ο笳Z言大行其道的時代,函數(shù)式編程語言有其特殊的優(yōu)勢
    2015-10-10
  • 最新JavaScript判斷是否是360瀏覽器方法

    最新JavaScript判斷是否是360瀏覽器方法

    這篇文章主要給大家介紹了關(guān)于最新JavaScript判斷是否是360瀏覽器方法的相關(guān)資料,我們在做項目的時候有用到判斷不同瀏覽器的這個需求,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下
    2023-07-07
  • Javascript BOM學(xué)習(xí)小結(jié)(六)

    Javascript BOM學(xué)習(xí)小結(jié)(六)

    BOM:BrowserObjectModel,瀏覽器對象模型,提供JS中對瀏覽器的各種操作的對象,是JS應(yīng)用中唯一沒有相關(guān)標(biāo)準(zhǔn)的部分,這事BOM經(jīng)常出現(xiàn)問題的所在,主要用于處理瀏覽器窗口與框架,瀏覽器特有的JS擴(kuò)展也被默認(rèn)為BOM的一部分,而各瀏覽器之間的公有對象就成了默認(rèn)的標(biāo)準(zhǔn)
    2015-11-11
  • js CSS3實現(xiàn)卡牌旋轉(zhuǎn)切換效果

    js CSS3實現(xiàn)卡牌旋轉(zhuǎn)切換效果

    這篇文章主要為大家詳細(xì)介紹了js CSS3實現(xiàn)卡牌旋轉(zhuǎn)切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • JS實現(xiàn)微信彈出搜索框 多條件查詢功能

    JS實現(xiàn)微信彈出搜索框 多條件查詢功能

    這篇文章主要介紹了JS實現(xiàn)微信彈出搜索框 多條件查詢功能的實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12
  • JavaScript異步回調(diào)的Promise模式封裝實例

    JavaScript異步回調(diào)的Promise模式封裝實例

    這篇文章主要介紹了JavaScript異步回調(diào)的Promise模式封裝實例,本文通過分析easyjs的源碼得出,實例均參考easyjs,需要的朋友可以參考下
    2014-06-06
  • 基于JS實現(xiàn)html中placeholder屬性提示文字效果示例

    基于JS實現(xiàn)html中placeholder屬性提示文字效果示例

    這篇文章主要介紹了基于JS實現(xiàn)html中placeholder屬性提示文字效果,涉及javascript事件響應(yīng)及頁面元素屬性動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2018-04-04
  • 淺談js中test()函數(shù)在正則中的使用

    淺談js中test()函數(shù)在正則中的使用

    下面小編就為大家?guī)硪黄獪\談js中test()函數(shù)在正則中的使用。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-08

最新評論