设计模式(惰性模块)

   惰性模式:减少每次代码 执行时重复的分支判断,通过对对象重新定义屏蔽原对象中的分支判断。

   浏览器兼容算是比较头疼的问题,大家都会遇到某些属性浏览器支持,有些不支持;就像早期的ie不支持addEventListener一样,每次需要针对ie写不同的代码判断去兼容。惰性模式就是为了减少每次重复判断。

   惰性模式两种定义方式:

   第一种:在文件加载初始化时候:(这是一种闭包方式,在初始化时候进行支持性判断后,重新定义)

 1             addevent = function(ele,type,fn) {
 2                 if(document.addEventListener) {
 3                     return function(ele, type, fn) {
 4                         ele.addEventListener(type, fn, false)
 5                     }
 6                 } else if(document.attachEvent) {
 7                     return function(ele, type, fn) {
 8                         ele.attachEvent("on" + type, fn);
 9                     }
10                 } else {
11                     return function(ele, type, fn) {
12                         ele["on" + type] = fn;
13                     }
14                 }
15             }();

    第二种:在第一次调用定义的方法时候,重新定义

    

 1             onevent = function(ele, type, fn) {
 2                 if(document.addEventListener) {
 3                     onevent = function(ele, type, fn) {
 4                         ele.addEventListener(type, fn, false)
 5                     }
 6                 } else if(document.attachEvent) {
 7                     onevent = function(ele, type, fn) {
 8                         ele.attachEvent("on" + type, fn);
 9                     };
10                 } else {
11                     onevent = function(ele, type, fn) {
12                         ele["on" + type] = fn;
13                     }
14                 }
15                 onevent(ele, type, fn)
16             }

     上述两种方法是为了减少每次在调用方法时候,重复性的判断。两种方法的区别:第一种:在加载初始化时候可能占资源,第二种:在第一次调用时候,需要重新定义,然后在方法最后需要自己再调用下新方法。两种方法可根据自己需要进行选择。

  

转载于:https://www.cnblogs.com/hsp-blog/p/5901030.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值