js设计模式之惰性模式

写过前端脚本的经常会遇到绑定事件方法,但是要交兼容IE浏览器和标准浏览器

例如:


var JsObject = {};

JsObject.on = function (dom,type,fn){

if(dom.addEventListener){//除去IE外的标准浏览器

dom.addEventListener(type,fn,false);

}else if(dom.attachEvent){//IE浏览器

dom.attachEvent('on'+type,fn);

}else{

dom['on' + type]  = fn;

}

}


当每次执行JsObject 的on方法时,都会进行条件判断,很繁琐,当执行完一次后,再次执行时,怎么样能不需要判断呢?当执行完一次判断后我们可以重写 on 方法可以避免重复判断。

##方法1:利用闭包,加载立即执行##

JsObject.on = function (dom,type,fn){

if(dom.addEventListener){//除去IE外的标准浏览器

return function(dom,type,fn){

dom.addEvenetListener(type,fn,false);

}

}else if(dom.attachEvent){//IE浏览器

return function(dom,type,fn){

dom.attachEvent('on'+type,fn);

}

}else{

return function(dom,type,fn){

dom['on' + type]  = fn;

}

}

}();




##方法2:是上述方法的延迟执行##

JsObject.on = function(dom,type,fn){

if(dom.addEventListener){

JsObject.on = function(dom,type,fn){

dom.addEventListener(type,fn,false);

}

}else if(dom.attachEvent){

JsObject.on = function(dom,type,fn){

dom.attachEvent('on'+type,fn);

}

}else{

JsObject.on = function(dom,type,fn){

dom['on' + type] = fn;

}

}

JsObject.on(dom,type,fn);

}


各人更倾向于使用第二种方案,此方案只有在调用此方法时候才执行,当没有使用此方法时,不占用浏览器内存


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值