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 相关文章推荐
javascript基本语法分析说明
Jun 15 Javascript
JavaScript 高级篇之函数 (四)
Apr 07 Javascript
让人印象深刻的10个jQuery手风琴效果应用
May 08 Javascript
jquery实现网站超链接和图片提示效果
Mar 21 Javascript
js如何判断用户是否是用微信浏览器
Jun 05 Javascript
cocos2dx骨骼动画Armature源码剖析(一)
Sep 08 Javascript
浅谈angular懒加载的一些坑
Aug 20 Javascript
Extjs让combobox写起来简洁又漂亮
Jan 05 Javascript
Node.js中的require.resolve方法使用简介
Apr 23 Javascript
微信小程序 开发之全局配置
May 05 Javascript
Vue中使用Sortable的示例代码
Apr 07 Javascript
详解Bootstrap 学习(一)入门
Apr 12 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/10/09 PHP
php获取是星期几的的一些常用姿势
2019/12/15 PHP
Prototype ObjectRange对象学习
2009/07/19 Javascript
基于JQuery的日期联动实现代码
2011/02/24 Javascript
浅析hasOwnProperty方法的应用
2013/11/20 Javascript
剖析Node.js异步编程中的回调与代码设计模式
2016/02/16 Javascript
给angular加上动画效遇到的问题总结
2016/02/17 Javascript
简单理解vue中Props属性
2016/10/27 Javascript
JavaScript实现翻页功能(附效果图)
2017/02/16 Javascript
js 中rewrap-ajax.js插件实例代码
2017/10/20 Javascript
解决option标签selected="selected"属性失效的问题
2017/11/06 Javascript
vue.js做一个简单的编辑菜谱功能
2018/05/08 Javascript
webpack css加载和图片加载的方法示例
2018/09/11 Javascript
vue-cli 构建骨架屏的方法示例
2018/11/08 Javascript
微信小程序实现的五星评价功能示例
2019/04/25 Javascript
Python字符串的encode与decode研究心得乱码问题解决方法
2009/03/23 Python
Python获取服务器信息的最简单实现方法
2015/03/05 Python
python爬虫爬取某站上海租房图片
2018/02/04 Python
python实现Windows电脑定时关机
2018/06/20 Python
Flask框架模板继承实现方法分析
2019/07/31 Python
Python中字典与恒等运算符的用法分析
2019/08/22 Python
python脚本第一行如何写
2020/08/30 Python
Bose法国官网:购买耳机、扬声器、家庭影院、专业音响
2017/12/21 全球购物
个人自我鉴定范文
2013/10/04 职场文书
企事业单位求职者的自我评价
2013/12/28 职场文书
车队司机自我鉴定
2014/03/02 职场文书
货车司机岗位职责
2014/03/18 职场文书
动漫设计与制作专业推荐信
2014/07/07 职场文书
2015年信息中心工作总结
2015/05/25 职场文书
百万英镑观后感
2015/06/09 职场文书
2016应届毕业生实习评语
2015/12/01 职场文书
应用最多的公文《通知》如何写?
2019/04/02 职场文书
2019年家电促销广告语集锦
2019/10/21 职场文书
如何开发一个渐进式Web应用程序PWA
2021/05/10 Javascript
SQL基础的查询语句
2021/11/11 MySQL
Mybatis-Plus 使用 @TableField 自动填充日期
2022/04/26 Java/Android