zoukankan      html  css  js  c++  java
  • 重写自己,减少判断 ---- 引发的思考

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

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

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

  • 相关阅读:
    Droppable(放置)组件
    Draggable(拖动)组件
    1.引入必要的文件 2.加载 UI 组件的方式 4.Parser 解析器
    mvc自带的异步表单提交
    MVC,jquery异步
    Container With Most Water
    Palindrome Number
    String to Integer (atoi)
    Merge k Sorted Lists
    Longest Valid Parentheses
  • 原文地址:https://www.cnblogs.com/mq0036/p/9413639.html
Copyright © 2011-2022 走看看