12.第三篇:装饰者模式

2018-12-10  本文已影响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')
})
上一篇 下一篇

猜你喜欢

热点阅读