重写本身,减小判断 ---- 引起的思考

重写本身如何减小判断?其实我也是学习别人的代码,才明白的。学习

看看下面的方法,方法名在内部都从新指向了处理代码,具体代码:spa

 //兼容的绑定事件方法
        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);
        }

通常人的写法是这样:.net

 function addHandler(target, eventType, handler) {          
            if (target.addEventListener) { //DOM2 Events 
                target.addEventListener(eventType, handler, false);
            } else { //IE 
                target.attachEvent("on" + eventType, handler);
            }           
        }

虽然多了几行代码,但思想彻底不同,通常人写的,每次绑定必而后判断,可人家写的就只有一次判断!!!只有一次!!!code

看完上面的代码,你是否有一种想法(^_!),不不是想干坏事啊?后果本身承担啊!就当我什么都没说过。blog

若是你有其余想法,不要忘记告诉我啊。事件

 

出处:https://blog.csdn.net/xuexiaodong009/article/details/51832056rem

相关文章
相关标签/搜索