zoukankan      html  css  js  c++  java
  • JS

    惰性函数可以优化频繁使用的函数。常用于函数库的编写、单例模式之中。

    应用:添加绑定函数

    1.初始版本:每一次调用都要进行 else-if 判断,其实第一次调用后,已经知道浏览器的环境,环境是固定的,可以在第一次判断后,就保留判断,可以优化多次调用函数的性能。

        function emit (element,type,func){
          if(element.addEventListener){
            emit = function (element,type,func) {
              element.addEventListener(type,func,false)
            } 
          }else if(element.attachEvent){
            emit = function (element,type,func) {
              element.attachEvent('on'+ type,func);
            }}else{
              emit = function (element,type,func) {
              emit = element['on'+type]=func;
            }
          }
          emit(element,type,func);
        }
        emit(box, 'click', fn1);

    2. 更改后的版本:在第一次调用后 emit函数被新的内容覆盖,不需要再进行 if 判断。

        function emit (element,type,func){
          if(element.addEventListener){
            emit = function (element,type,func) {
              element.addEventListener(type,func,false)
            } 
          }else if(element.attachEvent){
            emit = function (element,type,func) {
              element.attachEvent('on'+ type,func);
            }}else{
              emit = function (element,type,func) {
              emit = element['on'+type]=func;
            }
          }
          emit(element,type,func);
        }
        emit(box, 'click', fn1);
  • 相关阅读:
    Android自己主动升级框架
    一句话说清楚啥是delegate
    C#
    MySQL Community Server 5.6和MySQL Installer 5.6
    仿htc sense的弹性listView!
    双向队列(STL做法)
    余承东:未来5年中国大部分智能手机厂商消失
    P3808 【模版】AC自动机(简单版)
    P1103 书本整理
    P2580 于是他错误的点名开始了
  • 原文地址:https://www.cnblogs.com/-xiao/p/12504641.html
Copyright © 2011-2022 走看看