Js 职责链模式 简单理解

js 职责链模式 的简单理解。大叔的代码太高深了,不好理解。

function Handler(s) {
    this.successor = s || null;
    this.handle = function () {
        if (this.successor) {
            this.successor.handle();
        }
    }
}

var app = new Handler({
    handle: function () {
        console.log(‘app handle‘);
    }
});

var dialog = new Handler(app);
dialog.handle = function () {
    console.log(‘dialog before ...‘);
    app.handle(this);
    console.log(‘dialog after ...‘);
};
var button = new Handler(dialog);
button.handle = function () {
    console.log(‘button before ...‘);
    dialog.handle(this);
    console.log(‘button after ...‘);
};

button.handle();

输出结果:

button before ...
dialog before ...
app handle
dialog after ...
button after ...

引用  http://www.cnblogs.com/TomXu/archive/2012/04/10/2435381.html

时间: 2024-10-05 04:06:27

Js 职责链模式 简单理解的相关文章

JS 职责链模式

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <script> /*职责链模式 所有对象依次处理请求,1不能处理传给2,2不能处理传给3....*/ /*场景 打折 100以下不打折, 100-200 9折 200-400 8折*/ /*好处 处理对象分离,降低耦合度*/ functi

JS常用的设计模式(15)—— 职责链模式

职责链模式是一个对象A向另一个对象B发起请求,如果B不处理,可以把请求转给C,如果C不处理,又可以把请求转给D.一直到有一个对象愿意处理这个请求为止. 打个比方,客户让老板写个php程序.老板肯定不写,然后老板交给了部门经理.部门经理不愿意写,又交给项目经理.项目经理不会写,又交给程序员.最后由码农来完成. 在这个假设里, 有几条职责链模式的特点. 1 老板只跟部门经理打交道,部门经理只联系项目经理,项目经理只找码农的麻烦. 2 如果码农也不写,这个项目将会流产. 3 客户并不清楚这个程序最后是

深入理解JavaScript系列(38):设计模式之职责链模式

介绍 职责链模式(Chain of responsibility)是使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系.将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理他为止. 也就是说,请求以后,从第一个对象开始,链中收到请求的对象要么亲自处理它,要么转发给链中的下一个候选者.提交请求的对象并不明确知道哪一个对象将会处理它——也就是该请求有一个隐式的接受者(implicit receiver).根据运行时刻,任一候选者都可以响应相应的请求,候选者的数目是任意

5.js模式-职责链模式

1. 职责链模式 将对象连成一条链,并沿着这条链传递请求,直到有一个对象处理它为止. var chain = function(fn){ this.fn = fn; this.successor = null; } chain.prototype.setNextSuccessor = function(successor){ return this.successor = successor; } chain.prototype.passRequest = function(){ var ret

js原生设计模式——13桥接模式(相同业务逻辑抽象化处理的职责链模式)

桥接模式之多元化类之间的实例化调用实例 <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>桥接模式之多元化类之间的实例化调用</title>    <script type="text/javascript">    //多维类的声明和调用(有点像类职责链模式)   

重温设计模式(三)——职责链模式(chain of responsibility)

一. 写在前面的 这么多的设计模式,我觉得职责链是我第一次看上去最简单,可是回想起来却又最复杂的一个模式. 因此,这个文章我酝酿了很久,一直也没有胆量发出来,例子也是改了又改,可是仍然觉得不够合理.所以希望各位多多指教. 二. 什么是链 文章伊始,先让我们了解这个最基本的概念,什么是链. 我给链下了这样的定义: 1. 链是一系列节点的集合. 2. 链的各节点可灵活拆分再重组. 三. 何为职责链 职责链模式:使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系.将这个对象连成一条

设计模式 ( 十二 ) 职责链模式(Chain of Responsibility)(对象行为)

 设计模式(十二)职责链模式(Chain of Responsibility)(对象行为型) 1.概述 你去政府部门求人办事过吗?有时候你会遇到过官员踢球推责,你的问题在我这里能解决就解决.不能解决就推卸给另外个一个部门(对象).至于究竟谁来解决问题呢?政府部门就是为了能够避免屁民的请求与官员之间耦合在一起,让多个(部门)对象都有可能接收请求,将这些(部门)对象连接成一条链,而且沿着这条链传递请求.直到有(部门)对象处理它为止. 样例1:js的事件浮升机制 样例2: 2.问题 假设有多个对象都有

《设计模式》——职责链模式

职责链模式(Chain of Responsibility):使多个对象都有机会处理请求,从而避免请求者的发送者和接受者之间的耦合关系,这个对象连接成一条链,并沿着这条连传递该请求,直到有一个对象处理它为止. UML图如下 具体例子分为三步 第一步:设置一个抽象类,抽象类中有两个无返回值的方法,一个是设置继承者的方法(SetSuccessor),另外一个是抽象方法,这个抽象方法被子类重写来处理具体的请求. 第二步:设置三个具体的继承者子类,自己继承抽象类,三个子类分别是ConcreteHandl

Filter体现职责链模式

1. 前言 Filter-Filter 技术是servlet2.3 新添加?的功能.完毕的流程:对用户请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对server响应进行后处理. Filter体现了一种职责琏模式.那么他是怎样体现的呢? 2. 职责链模式 在详细的解释这个之前先看看职责链模式的定义:使多个对象都有机会处理请求 ,从而避免请求的发送者和接受者之间的耦合关系.将这个对象连成一个链,并沿着这条链传递请求,直到有一个对象处理它为止. 对于Filter而