JavaScript职责链模式概述


Posted in Javascript onSeptember 17, 2016

一、概述 

职责链模式(Chain of responsibility),就是使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系。将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理他为止。 

貌似和数据结构中的链表一样。 

但,不要搞混了,职责链可不等于链表哦,因为职责链可以在任何一个节点开始往下查找,而链表,则必须从头结点开始往下查找。 

比如,DOM事件机制中的冒泡事件就属于职责链,而捕获事件则属于链表。 

二、利用职责链模拟冒泡 

假设我们有三个对象:li、ul、div,三者关系图如下:

JavaScript职责链模式概述

比如,当我们触发li对象时,如果li没有阻止冒泡,那么将会传递给ul对象,到了ul,如果没有阻止冒泡,则会传递给div对象(假设这里div为根节点)。同理,ul、div。 

看到这儿,很清楚适合用职责链模式,编写这样的需求。 

但,怎么使用JavaScript实现职责链模式呢? 

如下,我们可以通过原型链的方式构建基本架构: 

function CreateDOM(obj){
  this.next = obj || null;
};  
CreateDOM.prototype = {
  handle: function(){
    if(this.next){
      this.next.handle();
    }
  }
};

每当我们利用CreateDOM构造函数,创建一个对象时,就将与之关联的对象传递进去(嗯,这样很链表)。 

然后,当我们触发某个对象,执行handle方法时,就可以沿着这条链,走下去了。 

但,需注意,当某个对象的handle属性覆盖了原型链中的handle时,怎么继续往下传呢? 

利用CreateDOM.prototype.handle.call(this);就好了。 

So,实现li、ul和div代码如下: 

var li = null, 
  ul = null, 
  div = null;
div = new CreateDOM();
div.handle = function(stopBubble){
  console.log('DIV');
  if(stopBubble){
    return;    
  }else{
    CreateDOM.prototype.handle.call(this);
  }
};
ul = new CreateDOM(div);
ul.handle = function(stopBubble){
  console.log('UL');
  if(stopBubble){
    return;    
  }else{
    CreateDOM.prototype.handle.call(this);
  }
};
li = new CreateDOM(ul);
li.handle = function(stopBubble){
  console.log('LI');
  if(stopBubble){
    return;    
  }else{
    CreateDOM.prototype.handle.call(this);
  }
};

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery获得同源iframe内body下标签的值的方法
Sep 25 Javascript
jQuery表单域选择器用法分析
Feb 10 Javascript
jquery根据一个值来选中select下的option实例代码
Aug 29 Javascript
详解Javascript中的原型OOP
Oct 12 Javascript
详解jQuery中的DOM操作
Dec 23 Javascript
在 Angular 中实现搜索关键字高亮示例
Mar 21 Javascript
浅谈node的事件机制
Oct 09 Javascript
详解ionic本地相册、拍照、裁剪、上传(单图完全版)
Oct 10 Javascript
关于JavaScript 数组你应该知道的事情(推荐)
Apr 10 Javascript
微信小程序云开发如何使用npm安装依赖
May 18 Javascript
原生js实现each方法实例代码详解
May 27 Javascript
快速对接payjq的个人微信支付接口过程解析
Aug 15 Javascript
JavaScript类的写法
Sep 17 #Javascript
使用JQuery选择HTML遍历函数的方法
Sep 17 #Javascript
jQuery leonaScroll 1.1 自定义滚动条插件(推荐)
Sep 17 #Javascript
JavaScript每天必学之数组和对象部分
Sep 17 #Javascript
JavaScript每天必学之基础知识
Sep 17 #Javascript
jQuery判断是否存在滚动条的简单方法
Sep 17 #Javascript
jQuery+CSS3实现四种应用广泛的导航条制作实例详解
Sep 17 #Javascript
You might like
3种平台下安装php4经验点滴
2006/10/09 PHP
php feof用来识别文件末尾字符的方法
2010/08/01 PHP
PHP缓存技术的使用说明
2011/08/06 PHP
克隆一个新项目的快捷方式
2013/04/10 PHP
PHP file_get_contents设置超时处理方法
2013/09/30 PHP
php连接与操作PostgreSQL数据库的方法
2014/12/25 PHP
PHP 中提示undefined index如何解决(多种方法)
2016/03/16 PHP
javascript 面向对象全新理练之继承与多态
2009/12/03 Javascript
为超链接加上disabled后的故事
2010/12/10 Javascript
jquery struts 验证唯一标识(公用方法)
2013/03/27 Javascript
计算新浪Weibo消息长度(还可以输入119字)
2013/07/02 Javascript
JSuggest自动匹配下拉框使用方法(示例代码)
2013/12/27 Javascript
Jquery.Form 异步提交表单的简单实例
2014/03/03 Javascript
ExtJS4给Combobox设置列表中的默认值示例
2014/05/02 Javascript
EasyUI,点击开启编辑框,并且编辑框获得焦点的方法
2015/03/01 Javascript
Json解析的方法小结
2016/06/22 Javascript
jQuery表单事件实例代码分享
2016/08/18 Javascript
基于vue2.0+vuex+localStorage开发的本地记事本示例
2017/02/28 Javascript
vue上传图片组件编写代码
2017/07/26 Javascript
Angular4集成ng2-file-upload的上传组件
2018/03/14 Javascript
实例讲解vue源码架构
2019/01/24 Javascript
vue中使用rem布局代码详解
2019/10/30 Javascript
Pycharm远程调试openstack的方法
2017/11/21 Python
学习Python selenium自动化网页抓取器
2018/01/20 Python
Python爬豆瓣电影实例
2018/02/23 Python
python利用Tesseract识别验证码的方法示例
2019/01/21 Python
使用python实现名片管理系统
2020/06/18 Python
Python安装第三方库攻略(pip和Anaconda)
2020/10/15 Python
Python使用eval函数执行动态标表达式过程详解
2020/10/17 Python
土木工程应届生求职信
2013/10/31 职场文书
计算机专业职业生涯规划范文
2014/01/19 职场文书
幼儿园安全检查制度
2014/01/30 职场文书
村干部承诺书
2014/03/28 职场文书
农村党支部承诺书
2015/04/30 职场文书
2015年统计员个人工作总结
2015/07/23 职场文书
Spring中bean集合注入的方法详解
2022/07/07 Java/Android