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+CSS实现菜单滑动伸展收缩(仿淘宝)
Mar 22 Javascript
jquery获取焦点和失去焦点事件代码
Apr 21 Javascript
基于JQuery的列表拖动排序实现代码
Oct 01 Javascript
学习JavaScript设计模式之状态模式
Jan 08 Javascript
AngularJs定制样式插入到ueditor中的问题小结
Aug 01 Javascript
原生js实现ajax方法(超简单)
Sep 20 Javascript
jquery css实现邮箱自动补全
Nov 14 Javascript
使用Angular CLI生成 Angular 5项目教程详解
Mar 18 Javascript
vue-cli脚手架-bulid下的配置文件
Mar 27 Javascript
vue基于element-ui的三级CheckBox复选框功能的实现代码
Oct 15 Javascript
Koa日志中间件封装开发详解
Mar 09 Javascript
Vue axios 将传递的json数据转为form data的例子
Oct 29 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采用curl实现伪造IP来源的方法
2014/11/21 PHP
PHP实现一维数组转二维数组的方法
2015/02/25 PHP
php源码分析之DZX1.5随机数函数random用法
2015/06/17 PHP
Yii框架表单提交验证功能分析
2017/01/07 PHP
javascript 无提示关闭窗口脚本
2009/08/17 Javascript
最新的10款jQuery内容滑块插件分享
2011/09/18 Javascript
Ext JS 4官方文档之三 -- 类体系概述与实践
2012/12/16 Javascript
使用JavaScript构建JSON格式字符串实现步骤
2013/03/22 Javascript
javascript实现了照片拖拽点击置顶的照片墙代码
2015/04/03 Javascript
JavaScript时间操作之年月日星期级联操作
2016/01/15 Javascript
原生js实现图片层叠轮播切换效果
2016/02/02 Javascript
JavaScript html5 canvas绘制时钟效果
2016/03/01 Javascript
多种jQuery绑定事件的实现方式
2016/06/13 Javascript
浅谈使用splice函数对数组中的元素进行删除时的注意事项
2016/12/04 Javascript
Bootstrap轮播图的使用和理解4
2016/12/14 Javascript
JS区分Object与Aarry的六种方法总结
2017/02/27 Javascript
从零开始学习Node.js系列教程之设置HTTP头的方法示例
2017/04/13 Javascript
js轮播图无缝滚动效果
2017/06/17 Javascript
jQuery validata插件实现方法
2017/06/25 jQuery
详解微信小程序设置底部导航栏目方法
2017/06/29 Javascript
React 项目迁移 Webpack Babel7的实现
2018/09/12 Javascript
Django与遗留的数据库整合的方法指南
2015/07/24 Python
合并百度影音的离线数据( with python 2.3)
2015/08/04 Python
python 在某.py文件中调用其他.py内的函数的方法
2019/06/25 Python
Scrapy 配置动态代理IP的实现
2020/09/28 Python
video.js支持m3u8格式直播的实现示例
2020/05/20 HTML / CSS
Foot Locker意大利官网:全球领先的运动鞋和服装零售商
2017/05/30 全球购物
巴西儿童时尚购物网站:Dinda
2019/08/14 全球购物
万代美国官网:PREMIUM BANDAI USA
2020/09/11 全球购物
新闻系毕业生推荐信
2013/11/16 职场文书
奥巴马演讲稿
2014/01/08 职场文书
食堂个人先进事迹
2014/01/22 职场文书
2014年圣诞节促销方案
2014/03/14 职场文书
2014年学校禁毒工作总结
2014/12/23 职场文书
小升初自荐信怎么写
2015/03/26 职场文书
搞笑婚礼主持词开场白
2015/11/24 职场文书