码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript---设计模式之职责链模式

时间:2018-02-11 21:22:12      阅读:146      评论:0      收藏:0      [点我收藏+]

标签:注意   应用   职责链   pre   node   write   中间件   func   rip   

概念

职责链模式是使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系。将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理他为止。

链中收到请求的对象要么亲自处理它,要么转发给下一个候选者。提交方并不明确有多少个对象会处理它,任一候选者都可以响应相应的请求,可以在运行时刻决定哪些候选者参与到链中。

作用

  1. dom的冒泡有些类似职责链
  2. nodejs当controller中有很多负责操作逻辑的时候拆分中间件
  3. 解耦发送者和接收者

注意事项

JavaScript中的每一次“.”是有代价的,要在必要的时候应用

<script type="text/javascript">
    function laoban(xiangmujingli){
        if(xiangmujingli){
            this.xiangmujingli = xiangmujingli;
        }
    }
    laoban.prototype.write = function (php) {
        this.xiangmujingli.write(php);
    }
    function xiangmujingli(coder) {
        if(coder){
            this.coder=coder;
        };
    }
    xiangmujingli.prototype.write=function (php) {
        this.coder.write(php);
    }
    function coder(php) {
        // this.write(php);
    }
    coder.prototype.write=function (php) {
        console.log("coding..." + php)
    }
    var begin = new laoban(new xiangmujingli(new coder()));
    begin.write("php");
</script>

 

JavaScript---设计模式之职责链模式

标签:注意   应用   职责链   pre   node   write   中间件   func   rip   

原文地址:https://www.cnblogs.com/xiaobaizhiqian/p/8443085.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!