zoukankan      html  css  js  c++  java
  • 性能优化之惰性函数

    我们正常封装一个兼容的绑定事件函数会这样写:

    function addEvent(dom, type, handle) {
        if (dom.addEventListener) {
            dom.addEventListener(type, handle, false)
        } else {
            dom.attachEvent('on' + type, handle)
        }
    }

    看起来没什么问题, 但是, 既然我们封装了这样一个函数, 那我们肯定会频繁调用它,

    每次调用都走一次if 判断   , 性能就会降低,  

    那我们就要想一个办法  , 只在第一次调用时判断一次, 后面再次调用就不用判断了,  

    这就是惰性函数的用法:

    function addEvent(dom, type, handle) {
        if (dom.addEventListener) {
            dom.addEventListener(type, handle, false);
            addEvent = function (dom, type, handle) {
                dom.addEventListener(type, handle, false);
            }
        } else {
            dom.attachEvent('on' + type, handle);
            addEvent = function (dom, type, handle) {
                dom.attachEvent('on' + type, handle);
            }
        }
    }

    直接在函数内部重写这个函数。

  • 相关阅读:
    最大生成树
    Codeforces#363 Div2
    AOJ2249最短路+最小费用
    Codeforces#364Div2
    POJ3268Dijkstra
    POJ3259负环判定
    Codeforces#362
    POJ3169差分约束系统
    POJ3723最小生成树
    hdu 4038 2011成都赛区网络赛H 贪心 ***
  • 原文地址:https://www.cnblogs.com/LHLVS/p/10816035.html
Copyright © 2011-2022 走看看