JavaScript 惰性函数

文章目录

JavaScript 惰性函数

概述

惰性函数通过函数的自我覆盖 ,实现了延迟执行性能优化

用法

性能优化

不使用惰性函数:

不使用惰性函数,每次调用 addEvent 都会进行一次 if-else 判断,造成额外的性能浪费。

javascript 复制代码
function addEvent(element, type, handler) {
  // 每次调用都要判断一次
  if (element.addEventListener) {
    element.addEventListener(type, handler, false);
  } else if (element.attachEvent) {
    element.attachEvent('on' + type, handler);
  } else {
    element['on' + type] = handler;
  }
}

for (let i = 0; i < 100; i++) {
  const btn = document.createElement('button');
  btn.textContent = `Button ${i}`;
  document.body.appendChild(btn);
  addEvent(btn, 'click', () => alert(`Button ${i} clicked!`));
}

使用惰性函数:

addEvent 函数在第一次被调用时,会根据浏览器特性,用一个最适合的函数版本把自己 "换掉"。后续所有调用都直接执行那个最优版本。

javascript 复制代码
function addEvent(element, type, handler) {
  // 首次调用:执行检测逻辑,并替换原函数
  if (element.addEventListener) {
    addEvent = function(element, type, handler) {
      element.addEventListener(type, handler, false);
    };
  } else if (element.attachEvent) {
    addEvent = function(element, type, handler) {
      element.attachEvent('on' + type, handler);
    };
  } else {
    addEvent = function(element, type, handler) {
      element['on' + type] = handler;
    };
  }

  // 执行新函数
  addEvent(element, type, handler);
}

for (let i = 0; i < 100; i++) {
  const btn = document.createElement('button');
  btn.textContent = `Button ${i}`;
  document.body.appendChild(btn);
  addEvent(btn, 'click', () => alert(`Button ${i} clicked!`));
}

延迟加载

不使用惰性函数:

在代码运行后,对象就会立即被创建,即使不使用也会被创建。

javascript 复制代码
const user = {
    name: "Tom",
    age: 18
}

function getUser() {
    return user;
}

const newUser = getUser()

使用惰性函数:

只有在方法调用时才会创建对象。

javascript 复制代码
let user = null

function getUser() {
    if (user == null) {
        user = {
            name: "Tom",
            age: 18
        }
    }
    return user;
}

const newUser = getUser()
相关推荐
天天向上102415 小时前
openlayers 加载Shapefile文件
前端·javascript·html
wuxianda103015 小时前
苹果App上架4.3a问题3天解决方案汇报总结
开发语言·javascript·uni-app·ecmascript·ios上架·苹果上架
琹箐15 小时前
今天吃什么干什么随机生成
javascript·css·css3
卷Java16 小时前
ReAct范式实战:让Agent学会边想边做
javascript·react.js·大模型·llm·ecmascript·multi-agent
吴声子夜歌16 小时前
Vue3——UI组件库Element Plus(二)
javascript·vue.js·ui·elementplus
zhensherlock16 小时前
Protocol Launcher 系列:Beorg 高效任务管理的协议支持
前端·javascript·typescript·node.js·自动化·github·js
ppandss116 小时前
JavaWeb从0到1-DAY3.1- Vue(ii)
前端·javascript·vue.js
M ? A16 小时前
Vue 转 React | VuReact编译工具快速入门
前端·javascript·vue.js·后端·react.js·面试·vureact
qq_4275398316 小时前
iframe 嵌入预览 PDF ,禁用右键菜单、打印下载按钮不展示
前端·javascript·vue.js·pdf
ZC跨境爬虫16 小时前
跟着 MDN 学 HTML day_3:(表单CSS美化实战与盒子模型三大核心属性详解)
前端·javascript·css·html