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

JavaScript設(shè)計(jì)模式之代理模式實(shí)例分析

 更新時(shí)間:2019年01月16日 11:51:51   作者:吳封斌技術(shù)博客  
這篇文章主要介紹了JavaScript設(shè)計(jì)模式之代理模式,簡(jiǎn)單描述了代理模式的概念、原理并結(jié)合實(shí)例形式分析了javascript代理模式的相關(guān)實(shí)現(xiàn)與使用技巧,需要的朋友可以參考下

本文實(shí)例講述了JavaScript設(shè)計(jì)模式之代理模式。分享給大家供大家參考,具體如下:

代理模式的定義,代理是一個(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)講更是重要)。

代理模式有兩種分類:

(1)普通代理

(2)惰性代理

具體看下面的例子

第一,普通代理模式

步驟一,接口檢驗(yàn)文件的引用

//定義一個(gè)靜態(tài)方法來(lái)實(shí)現(xiàn)接口與實(shí)現(xiàn)類的直接檢驗(yàn)
//靜態(tài)方法不要寫(xiě)出Interface.prototype ,因?yàn)檫@是寫(xiě)到接口的原型鏈上的
//我們要把靜態(tài)的函數(shù)直接寫(xiě)到類層次上
//定義一個(gè)接口類
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ù)名必須是字符串類型");
    }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類型
    if(inter.constructor!=Interface){
      throw new Error("如果是接口類的話,就必須是Interface類型");
    }
    //判斷接口中的方法是否全部實(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)類中必須有方法名字與接口中所用方法名相同
        throw new Error("實(shí)現(xiàn)類中沒(méi)有完全實(shí)現(xiàn)接口中的所有方法")
      }
    }
  }
}

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

(1)圖書(shū)類

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

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

//目標(biāo)類
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);//類似于目標(biāo)類的引用
     //加書(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)類和代理同時(shí)實(shí)現(xiàn)了同一接口。代理中一次性對(duì)目標(biāo)類進(jìn)行實(shí)例,然后值訪問(wèn)到目標(biāo)類中的方法。

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

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

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

//惰性代理---在使用時(shí)在初始化目標(biāo)類的引用
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ò)程,如圖

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

相關(guān)文章

  • javascript中HTMLDOM操作詳解

    javascript中HTMLDOM操作詳解

    這篇文章主要介紹了javascript中HTMLDOM操作詳解,需要的朋友可以參考下
    2014-12-12
  • ES6 class的應(yīng)用實(shí)例分析

    ES6 class的應(yīng)用實(shí)例分析

    這篇文章主要介紹了ES6 class的應(yīng)用,結(jié)合實(shí)例形式分析了class在ES6面向?qū)ο蟪绦蛟O(shè)計(jì)中定義類的相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • javascript刪除元素節(jié)點(diǎn)removeChild()用法實(shí)例

    javascript刪除元素節(jié)點(diǎn)removeChild()用法實(shí)例

    這篇文章主要介紹了javascript刪除元素節(jié)點(diǎn)removeChild()用法,實(shí)例分析了removeChild()方法移除節(jié)點(diǎn)的使用技巧,需要的朋友可以參考下
    2015-05-05
  • JS手搓P(guān)romise的常見(jiàn)方法總結(jié)

    JS手搓P(guān)romise的常見(jiàn)方法總結(jié)

    這篇文章主要為大家詳細(xì)介紹了JavaScript中手寫(xiě)Promise的一些常見(jiàn)方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下
    2023-09-09
  • 前端URL拼接路徑參數(shù)具體實(shí)現(xiàn)代碼

    前端URL拼接路徑參數(shù)具體實(shí)現(xiàn)代碼

    這篇文章主要給大家介紹了關(guān)于前端URL拼接路徑參數(shù)具體實(shí)現(xiàn)的相關(guān)資料,url地址拼接是經(jīng)常會(huì)遇到的問(wèn)題,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • JavaScript 高效運(yùn)行代碼分析

    JavaScript 高效運(yùn)行代碼分析

    傳統(tǒng)上,網(wǎng)頁(yè)中不會(huì)有大量的腳本,至少腳本很少會(huì)影響網(wǎng)頁(yè)的性能。
    2010-03-03
  • js正則表達(dá)式中test,exec,match方法的區(qū)別說(shuō)明

    js正則表達(dá)式中test,exec,match方法的區(qū)別說(shuō)明

    本篇文章主要是對(duì)js正則表達(dá)式中test,exec,match方法的區(qū)別進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2014-01-01
  • 微信小程序開(kāi)發(fā)中的疑問(wèn)解答匯總

    微信小程序開(kāi)發(fā)中的疑問(wèn)解答匯總

    這篇文章主要給大家總結(jié)了關(guān)于微信小程序開(kāi)發(fā)中的各種疑問(wèn)解答,文中將在微信小程序開(kāi)發(fā)中可能遇到的問(wèn)題都進(jìn)行了整理和解答,對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-07-07
  • 淺談Javascript事件模擬

    淺談Javascript事件模擬

    事件是用來(lái)描述網(wǎng)頁(yè)中某一特定有趣時(shí)刻的,眾所周知事件通常是在由用戶和瀏覽器進(jìn)行交互時(shí)觸發(fā),其實(shí)不然,通過(guò)Javascript可以在任何時(shí)間觸發(fā)特定的事件,并且這些事件與瀏覽器創(chuàng)建的事件是相同的
    2012-06-06
  • Bootstrap源碼解讀導(dǎo)航(6)

    Bootstrap源碼解讀導(dǎo)航(6)

    這篇文章主要源碼解讀了Bootstrap導(dǎo)航,介紹了Bootstrap各式各樣的導(dǎo)航,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12

最新評(píng)論