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

JavaScript設(shè)計(jì)模式之責(zé)任鏈模式實(shí)例分析

 更新時(shí)間:2019年01月16日 12:03:10   作者:吳封斌技術(shù)博客  
這篇文章主要介紹了JavaScript設(shè)計(jì)模式之責(zé)任鏈模式,結(jié)合實(shí)例形式分析了責(zé)任鏈模式的概念、原理及具體定義與使用技巧,需要的朋友可以參考下

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

介紹

責(zé)任鏈模式(Chain of responsibility)是使多個(gè)對(duì)象都有機(jī)會(huì)處理請(qǐng)求,從而避免請(qǐng)求的發(fā)送者和接受者之間的耦合關(guān)系。將對(duì)象連成一條鏈,并沿著這條鏈傳遞該請(qǐng)求,直到有一個(gè)對(duì)象處理他為止。

請(qǐng)求以后,從第一個(gè)對(duì)象開(kāi)始,鏈中收到請(qǐng)求的對(duì)象要么親自處理它,要么轉(zhuǎn)發(fā)給鏈中的下一個(gè)候選者。提交請(qǐng)求的對(duì)象并不知道哪一個(gè)對(duì)象將會(huì)處理它——也就是該請(qǐng)求有一個(gè)隱式的接受者(implicit receiver)。在運(yùn)行時(shí),任一候選者都可以響應(yīng)相應(yīng)的請(qǐng)求,候選者的數(shù)目是任意的,也可以在運(yùn)行時(shí)刻決定哪些候選者參與到鏈中。

圖解為:

正文

(1)由于類一般是與接口打交道的,為此我們先定義一個(gè)規(guī)范類中方法的接口,代碼為

//定義一個(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)接口中的所有方法")
      }
    }
  }
}

(2)使用定義一個(gè)書(shū)店的接口

var bookShop=new Interface("bookShop",["addBook","findBook","showBooks"]);//書(shū)店接口

(3)定義一個(gè)書(shū)類

var Book=function (bNm,bName,bAuthor,bType) {
  this.bNm=bNm;
  this.bName=bName;
  this.bAuthor=bAuthor;
  this.bType=bType;
}

(4)書(shū)店類=書(shū)架+圖書(shū)

1:在書(shū)店中添加書(shū)架和圖書(shū)

var pcatBookShop=(function(){
 //書(shū)架
  var jsBooks = new Array();//js書(shū)架
  var cBooks = new Array();//c書(shū)架
  var javaBooks = new Array();//java書(shū)架
   //內(nèi)部類1
  function AddJsBooks(book) {
    if(book.bType=="Js"){
      jsBooks.push(book);
    }else {
      AddJsBooks.successor(book);
    }
  }
  //內(nèi)部類2
  function AddJavaBooks(book) {
    if(book.bType=="Java"){
      javaBooks.push(book);
    }else {
      AddJavaBooks.successor(book);
    }
  }
  //內(nèi)部類3
  function AddCBooks(book) {
    if(book.bType=="C"){
      cBooks.push(book);
    }else {
      AddCBooks.successor(book);
    }
  }
})()

2:擴(kuò)展設(shè)置責(zé)任鏈的方法(擴(kuò)展在windows上)

//擴(kuò)展window屬性
window.setSuccessor=function (after,before) {
  after.successor=before;//引用的執(zhí)行
}

3:設(shè)置責(zé)任鏈,將每個(gè)對(duì)象鏈接起來(lái)

//設(shè)置責(zé)任鏈-----串起來(lái)
setSuccessor(AddJsBooks,AddJavaBooks);
setSuccessor(AddJavaBooks,AddCBooks);

(5)查詢圖書(shū)的方法:通過(guò)圖書(shū)編號(hào)和圖書(shū)圖書(shū)名稱

 

/**********查詢書(shū)籍************/
  var bookList = null;
  function FindBbn(keyword) {
    //鏈的頭部來(lái)初始化參數(shù)
    if(!bookList){
      bookList=jsBooks.concat(cBooks).concat(javaBooks);
      var book = new Array();
      book=bookList.filter(function (book) {//對(duì)booklist進(jìn)行過(guò)濾,過(guò)濾的條件為匿名函數(shù)
        if(book.bName.indexOf(keyword)!=-1){
             return true;
        }else {
          return false;
        }
      });
      //我要進(jìn)行鏈?zhǔn)讲樵?
      return book.concat(FindBbn.successor(keyword));
    }
  };
  function FindByName(keyword,book){
    var book = book;
    book = bookList.filter(function(book){
      if(book.bName.indexOf(keyword) != -1){
        return true;
      }else{
        return false;
      }
    });
    return book;
  }

注意,數(shù)組的filter方法擴(kuò)展代碼如下

Function.prototype.method=function (name,fn) {
  this.prototype[name]=fn;
  return this;
}
if(!Array.prototype.filter){
  Array.method("filter",function (fn,thisObj) {
    var scope=thisObj||window;
    var a=[];
    for(var i=0;i<this.length;i++){
      if(!fn.call(scope,this[i],i,this));{
        continue;
      }
      a.push(this[i]);
    }
    //返回過(guò)濾好數(shù)據(jù)
    return a;
  })
}

(6)規(guī)劃責(zé)任鏈

setSuccessor(FindBbn,FindByName);

(7)真正的書(shū)店類(實(shí)現(xiàn)接口的類)

 return function () {
    this.addBook=function (book) {
      if(book instanceof Book){
        AddJsBooks(book);//因?yàn)槲抑勒l(shuí)是鏈的入口
      }
    };
    this.findBook=function (keyword) {
      return FindBbn(keyword);//游泳規(guī)劃的責(zé)任鏈可以從頭到尾的查詢?nèi)?,F(xiàn)indBbn沒(méi)有則到FindByName中查詢
    }
    this.showBooks=function () {
      document.write("JS類圖書(shū)"+jsBooks.toSource()+"<br>");
      document.write("Java類圖書(shū)"+javaBooks.toSource()+"<br>");
      document.write("C類圖書(shū)"+cBooks.toSource()+"<br>");
      //自動(dòng)生產(chǎn)----------
      document.write(cpoyStr(60,"-")+"<br>");
    }
  }

注意,在window上擴(kuò)展一個(gè)可以自動(dòng)生成“---------------”的方法

//擴(kuò)展一個(gè)可以自動(dòng)生產(chǎn)-----的方法
window.cpoyStr=function (num,str) {
  var newStr="";
  for(var i=0;i<num;i++){
   newStr+=str;
  }
  return newStr;
};

(8)使用書(shū)店

1:添加書(shū)

var pb = new pcatBookShop();
pb.addBook(new Book("00101","JAVA","JIM","JAVA"));
pb.addBook(new Book("00201","C#","world","C"));
pb.addBook(new Book("00202","C++/C","Hello","C"));
pb.addBook(new Book("00301","JAVASCRIPT","Good","JS"));

2:對(duì)書(shū)架上的書(shū)進(jìn)行操作-----展示

//展示
pb.showBooks();
document.write(pb.findBook("C").toSource())

為此我們基本上完成了對(duì)責(zé)任鏈模式的使用方式的基本學(xué)習(xí)。

更多關(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)文章

  • 前端構(gòu)建工具之gulp的語(yǔ)法教程

    前端構(gòu)建工具之gulp的語(yǔ)法教程

    這篇文章主要給大家介紹了關(guān)于前端構(gòu)建工具之gulp語(yǔ)法的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)跟著小編一起學(xué)習(xí)學(xué)習(xí)下吧。
    2017-06-06
  • 詳解在JavaScript中如何判斷變量類型

    詳解在JavaScript中如何判斷變量類型

    JavaScript是一個(gè)動(dòng)態(tài)類型語(yǔ)言,在運(yùn)行時(shí)獲取變量類型是常用操作。本文將通過(guò)示例為大家詳細(xì)講講在JavaScript中如何判斷變量類型,感興趣的可以學(xué)習(xí)一下
    2022-07-07
  • JS開(kāi)發(fā)自己的類庫(kù)實(shí)例分析

    JS開(kāi)發(fā)自己的類庫(kù)實(shí)例分析

    這篇文章主要介紹了JS開(kāi)發(fā)自己的類庫(kù),結(jié)合實(shí)例形式分析了javascript開(kāi)發(fā)類庫(kù)的原理、組成及實(shí)現(xiàn)方法,需要的朋友可以參考下
    2019-08-08
  • canvas實(shí)現(xiàn)十二星座星空?qǐng)D

    canvas實(shí)現(xiàn)十二星座星空?qǐng)D

    本文主要分享了canvas實(shí)現(xiàn)十二星座星空?qǐng)D的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02
  • 一文教會(huì)你微信小程序如何實(shí)現(xiàn)登錄

    一文教會(huì)你微信小程序如何實(shí)現(xiàn)登錄

    微信小程序頁(yè)面畫(huà)好后,需要開(kāi)始做一系列和用戶的交互功能了,首先就是登錄,這篇文章主要給大家介紹了關(guān)于微信小程序如何實(shí)現(xiàn)登錄的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • js 得到文件后綴(通過(guò)正則實(shí)現(xiàn))

    js 得到文件后綴(通過(guò)正則實(shí)現(xiàn))

    使用js獲取文件的后綴,有個(gè)不錯(cuò)的正則,大家可以借用下,具體如下,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助
    2013-07-07
  • 關(guān)于js遍歷表格的實(shí)例

    關(guān)于js遍歷表格的實(shí)例

    js可以利用dom非常輕松的就可以遍歷一個(gè)表格。當(dāng)然只要是dom中有的所有對(duì)象都可以通過(guò)js來(lái)訪問(wèn)和處理
    2013-07-07
  • JavaScript?中如何攔截全局?Fetch?API?的請(qǐng)求和響應(yīng)問(wèn)題

    JavaScript?中如何攔截全局?Fetch?API?的請(qǐng)求和響應(yīng)問(wèn)題

    在本文中,我們介紹了什么是 JavaScript 攔截器,學(xué)習(xí)了如何通過(guò)給 Fetch API 使用猴子補(bǔ)丁和使用 fetch-intercept 庫(kù)來(lái)創(chuàng)建攔截器,對(duì)js攔截全局Fetch?API的請(qǐng)求和響應(yīng)知識(shí)感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • JS判斷數(shù)組是否包含某元素實(shí)現(xiàn)方法匯總

    JS判斷數(shù)組是否包含某元素實(shí)現(xiàn)方法匯總

    這篇文章主要介紹了JS判斷數(shù)組是否包含某元素實(shí)現(xiàn)方法匯總,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 基于JS實(shí)現(xiàn)頁(yè)面視頻video標(biāo)簽禁止下載(下載按鈕+右擊菜單)

    基于JS實(shí)現(xiàn)頁(yè)面視頻video標(biāo)簽禁止下載(下載按鈕+右擊菜單)

    最近做項(xiàng)目遇到這樣的需求,禁止用戶瀏覽頁(yè)面的時(shí)候下載頁(yè)面的視頻,網(wǎng)上看到下載視頻的方法有兩種,本文對(duì)每種方法做詳細(xì)分析,對(duì)js禁止下載視頻相關(guān)知識(shí)感興趣的朋友一起看看吧
    2024-02-02

最新評(píng)論