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 相关文章推荐
一个对于Array的简单扩展
Oct 03 Javascript
从数组中随机取x条不重复数据的JS代码
Dec 24 Javascript
javascript学习笔记(七)Ajax和Http状态码
Oct 08 Javascript
javascript实现详细时间提醒信息效果的方法
Mar 11 Javascript
javascript实现框架高度随内容改变的方法
Jul 23 Javascript
JavaScript生成SQL查询表单的方法
Aug 13 Javascript
jQuery实现可用于博客的动态滑动菜单完整实例
Sep 17 Javascript
详解Matlab中 sort 函数用法
Mar 20 Javascript
详解JavaScript异步编程中jQuery的promise对象的作用
May 03 Javascript
js实现hashtable的赋值、取值、遍历操作实例详解
Dec 25 Javascript
VUE重点问题总结
Mar 19 Javascript
vue 解决IOS10低版本白屏的问题
Nov 17 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
中篇:安装及配置PHP
2006/12/13 PHP
PHP使用curl模拟post上传及接收文件的方法
2016/03/04 PHP
php实现三级级联下拉框
2016/04/17 PHP
W3C Group的JavaScript1.8 新特性介绍
2009/05/19 Javascript
javascript对select标签的控制(option选项/select)
2013/01/31 Javascript
获取元素距离浏览器周边的位置的方法getBoundingClientRect
2013/04/17 Javascript
js数组中如何随机取出一个值
2014/06/13 Javascript
jquery trigger伪造a标签的click事件取代window.open方法
2014/06/23 Javascript
使用node.js 获取客户端信息代码分享
2014/11/26 Javascript
JavaScript设计模式之建造者模式介绍
2014/12/28 Javascript
简介JavaScript中的setTime()方法的使用
2015/06/11 Javascript
jQuery简单实现两级下拉菜单效果代码
2015/09/15 Javascript
JavaScript的Backbone.js框架的一些使用建议整理
2016/02/14 Javascript
javascript验证手机号和实现星号(*)代替实例
2016/08/16 Javascript
详解HTML5 使用video标签实现选择摄像头功能
2017/10/25 Javascript
vue init失败简单解决方法(终极版)
2017/12/22 Javascript
express如何使用session与cookie的方法
2018/01/30 Javascript
使用Vue的slot插槽分发父组件内容实现高度复用、更加灵活的组件(推荐)
2018/05/01 Javascript
element-ui循环显示radio控件信息的方法
2018/08/24 Javascript
layui实现文件或图片上传记录
2018/08/28 Javascript
一看就会的vuex实现登录验证(附案例)
2020/01/09 Javascript
JS前端广告拦截实现原理解析
2020/02/17 Javascript
JS如何实现手机端输入验证码效果
2020/05/13 Javascript
Python SQLAlchemy基本操作和常用技巧(包含大量实例,非常好)
2014/05/06 Python
优化Python代码使其加快作用域内的查找
2015/03/30 Python
python实现折半查找和归并排序算法
2017/04/14 Python
Python基于QRCode实现生成二维码的方法【下载,安装,调用等】
2017/07/11 Python
django admin后台添加导出excel功能示例代码
2019/05/15 Python
基于python3 pyQt5 QtDesignner实现窗口化猜数字游戏功能
2019/07/15 Python
Python 获取windows桌面路径的5种方法小结
2019/07/15 Python
美国葡萄酒网上商店:Martha Stewart Wine Co.
2019/03/17 全球购物
税务专业毕业生自荐信
2013/11/10 职场文书
职专应届生求职信
2013/11/16 职场文书
皮肤科医师岗位职责
2013/12/04 职场文书
个人查摆问题及整改措施
2014/10/16 职场文书
Win10 heic文件怎么打开 ? Win10 heic文件打开教程
2022/04/06 数码科技