美文网首页
12.第三篇:装饰者模式

12.第三篇:装饰者模式

作者: 爱吃鱼的肥兔子 | 来源:发表于2018-12-10 14:01 被阅读0次

本文摘自 《JavaScript 设计模式》张容铭 著 版权归原作者所有

  • 装饰旧方法(已有的功能对象)。修改历史代码的时候,可以用装饰者模式,在不修改原有代码的基础上,对旧代码的事件进行修改。
var con = document.getElmentById('con');
con.onclick = function(){
  console.log("old fn");
}
var decorator = function(id,fn){
  var con = document.getElmentById('con');
  // 如果该DOM已有绑定事件
  if(typeof dom.onclick === 'function'){
    var oldFun = dom.onclick;
    // 绑定新事件
    dom.onclick = function(){
      // 执行老事件
      oldFun();
      //执行新绑定的事件
      fn();
    }
  }else{
    // 如果该DOM没有绑定事件,则为DOM添加事件
    dom.onclick = fn;
  }
}
decorator('con',function(){
  console.log('new function')
})

相关文章

  • 12.第三篇:装饰者模式

    本文摘自 《JavaScript 设计模式》张容铭 著 版权归原作者所有 装饰旧方法(已有的功能对象)。修改历史代...

  • 如何利用装饰者模式在不改变原有对象的基础上扩展功能

    目录 什么是装饰者模式 普通示例 装饰者模式示例 类图关系 装饰者模式使用场景 装饰者模式优点 装饰者模式缺点 什...

  • 装饰者模式

    装饰者模式 装饰者模式和适配器模式对比 装饰者模式 是一种特别的适配器模式 装饰者与被装饰者都要实现同一个接口,主...

  • JavaScript 设计模式(中)——12. 装饰者模式

    12 装饰者模式 装饰者模式定义为给对象动态地增加职责的方式;装饰者模式能够在不改变对象自身的基础上,在程序运行期...

  • java IO 的知识总结

    装饰者模式 因为java的IO是基于装饰者模式设计的,所以要了解掌握IO 必须要先清楚什么事装饰者模式(装饰者模式...

  • 设计模式:第三篇--装饰者模式

    装饰者模式简介 案例:星巴克- 1、小白设计:单纯继承- 2、使用装饰者模式- 3、jdk的I/O框架- 4、案例...

  • 设计模式-装饰者模式

    装饰者模式概念: 装饰者模式又名包装(Wrapper)模式。装饰者模式以对客户端透明的方式扩展对象的功能,是继承关...

  • java - 装饰者模式

    装饰者模式 装饰者模式:动态将责任添加到对象上。如果需要扩展功能,装饰者提供了比继承更有弹性的解决方案。装饰者模式...

  • 设计模式之装饰者模式(Decorator Pattern)

    What: 装饰者模式又名包装(Wrapper)模式。装饰者模式动态地将责任附加到对象身上。若要扩展功能,装饰者提...

  • 装饰者(Decorator)模式

    装饰者(Decorator)模式装饰模式又名包装(Wrapper)模式。装饰模式是继承关系的一个替代方案。装饰模式...

网友评论

      本文标题:12.第三篇:装饰者模式

      本文链接:https://www.haomeiwen.com/subject/oudrhqtx.html