亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在JavaScript中使用代理模式

發布時間:2021-03-31 17:06:19 來源:億速云 閱讀:181 作者:Leah 欄目:web開發

怎么在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中使用代理模式

看完上述內容,你們掌握怎么在JavaScript中使用代理模式的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

边坝县| 芜湖市| 虹口区| 宜兴市| 启东市| 武强县| 韶关市| 湟源县| 句容市| 基隆市| 保靖县| 大兴区| 大余县| 齐河县| 社旗县| 福安市| 开阳县| 当雄县| 瓮安县| 富宁县| 大邑县| 马山县| 炎陵县| 新巴尔虎右旗| 怀集县| 平原县| 鸡东县| 镇赉县| 朝阳县| 聂荣县| 青阳县| 澄迈县| 凤台县| 信宜市| 周至县| 东乌珠穆沁旗| 高阳县| 慈利县| 油尖旺区| 义乌市| 鄂州市|