重写自己,减少判断 ---- 引发的思考
重写自己如何减少判断?其实我也是学习别人的代码,才明白的。
看看下面的方法,方法名在内部都重新指向了处理代码,具体代码:
//兼容的绑定事件方法 function addHandler(target, eventType, handler) { //重写自己 if (target.addEventListener) { //DOM2 Events addHandler = function (target, eventType, handler) { target.addEventListener(eventType, handler, false); }; } else { //IE addHandler = function (target, eventType, handler) { target.attachEvent("on" + eventType, handler); }; } //关键,调用新方法,重写自己,减少判断,第二次调用时,使用新方法,没有判断 addHandler(target, eventType, handler); } function removeHandler(target, eventType, handler) { //o//重写自己 if (target.removeEventListener) { //DOM2 Events removeHandler = function (target, eventType, handler) { target.addEventListener(eventType, handler, false); }; } else { //IE removeHandler = function (target, eventType, handler) { target.detachEvent("on" + eventType, handler); }; } //关键,调用新方法,重写自己,减少判断,第二次调用时,使用新方法,没有判断 removeHandler(target, eventType, handler); }
一般人的写法是这样:
function addHandler(target, eventType, handler) { if (target.addEventListener) { //DOM2 Events target.addEventListener(eventType, handler, false); } else { //IE target.attachEvent("on" + eventType, handler); } }
虽然多了几行代码,但思想完全不一样,一般人写的,每次绑定必然后判断,可人家写的就只有一次判断!!!只有一次!!!
看完上面的代码,你是否有一种想法(^_!),不不是想干坏事啊?后果自己承担啊!就当我什么都没说过。
如果你有其他想法,不要忘记告诉我啊。
出处:https://blog.csdn.net/xuexiaodong009/article/details/51832056
关注我】。(●'◡'●)
如果,您希望更容易地发现我的新博客,不妨点击一下绿色通道的【因为,我的写作热情也离不开您的肯定与支持,感谢您的阅读,我是【Jack_孟】!
本文来自博客园,作者:jack_Meng,转载请注明原文链接:https://www.cnblogs.com/mq0036/p/9413639.html
【免责声明】本文来自源于网络,如涉及版权或侵权问题,请及时联系我们,我们将第一时间删除或更改!