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插件制作 自增长输入框实现代码
Aug 17 jQuery
javascript中兼容主流浏览器的动态生成iframe方法
May 05 Javascript
使用typeof方法判断undefined类型
Sep 09 Javascript
使用js画图之饼图
Jan 12 Javascript
JavaScript 模块的循环加载实现方法
Dec 13 Javascript
详解javascript实现瀑布流列式布局
Jan 29 Javascript
Angularjs的启动过程分析
Jul 18 Javascript
详解动画插件wow.js的使用方法
Sep 13 Javascript
详解react-native WebView 返回处理(非回调方法可解决)
Feb 27 Javascript
jQuery基于闭包实现的显示与隐藏div功能示例
Jun 09 jQuery
vue.js响应式原理解析与实现
Jun 22 Javascript
Vue中多个元素、组件的过渡及列表过渡的方法示例
Feb 13 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处理excel cvs表格的方法实例介绍
2013/05/13 PHP
Laravel框架实现model层的增删改查(CURD)操作示例
2018/05/12 PHP
javascript 触发事件列表 比较不错
2009/09/03 Javascript
jquery提升性能最佳实践小结
2010/12/06 Javascript
使用JavaScript动态设置样式实现代码及演示动画
2013/01/25 Javascript
js同源策略详解
2015/05/21 Javascript
jquery中用jsonp实现搜索框功能
2016/10/18 Javascript
JS文件/图片从电脑里面拖拽到浏览器上传文件/图片
2017/03/08 Javascript
JavaScript制作简单的框选图表
2017/05/15 Javascript
React Native时间转换格式工具类分享
2017/10/24 Javascript
浅谈webpack下的AOP式无侵入注入
2017/11/12 Javascript
mint-ui 时间插件使用及获取选择值的方法
2018/02/09 Javascript
jquery ajaxfileuplod 上传文件 essyui laoding 效果【防止重复上传文件】
2018/05/26 jQuery
详解ECMAScript typeof用法
2018/07/25 Javascript
分享5个好用的javascript文件上传插件
2018/09/16 Javascript
ES6 Object.assign()的用法及其使用
2020/01/18 Javascript
Vue组件间的通信pubsub-js实现步骤解析
2020/03/11 Javascript
如何使用JavaScript实现无缝滚动自动播放轮播图效果
2020/08/20 Javascript
最大K个数问题的Python版解法总结
2016/06/16 Python
浅谈对yield的初步理解
2017/05/29 Python
在django中使用自定义标签实现分页功能
2017/07/04 Python
浅谈python新式类和旧式类区别
2019/04/26 Python
更新pip3与pyttsx3文字语音转换的实现方法
2019/08/08 Python
Python 日期的转换及计算的具体使用详解
2020/01/16 Python
Python如何存储数据到json文件
2020/03/09 Python
HTML5 video视频字幕的使用和制作方法
2018/05/03 HTML / CSS
Zadig&Voltaire官网:法国时装品牌
2018/01/05 全球购物
从当地商店送来的杂货:Instacart
2018/08/19 全球购物
Optimalprint加拿大:在线打印服务
2020/04/03 全球购物
在阿联酋购买翻新手机和平板电脑:Teckzu
2021/02/12 全球购物
C# Debug和Testing相关面试题
2015/10/25 面试题
JDBC操作数据库的基本流程是什么
2014/10/28 面试题
如何清空Session
2015/02/23 面试题
松材线虫病防治方案
2014/06/15 职场文书
三好学生主要事迹怎么写
2015/11/03 职场文书
MySQL的意向共享锁、意向排它锁和死锁
2022/07/15 MySQL