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()
相关推荐
安妮的小熊呢5 分钟前
CRMEB标准版v6.0: 商城DIY装修新升级,PS级自由设计!
运维·javascript·平面·信息可视化·小程序·开源软件
安生生申5 分钟前
uni-app 连接 JDY-31 蓝牙串口模块实践
c语言·前端·javascript·stm32·单片机·嵌入式硬件·uni-app
Liu.77410 分钟前
Vue3结合Element Plus封装点击查看大图的自定义指令
javascript·vue.js·elementui
lqj_本人10 分钟前
鸿蒙PC:electron-markdownify 从普通 Electron 迁移到 OpenHarmony Electron HAP 的完整实践
前端·javascript·electron
之歆10 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
Maimai1080810 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
candyTong10 小时前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
卡卡军13 小时前
agmd 1.0 重磅升级——Rust 重写,性能起飞
javascript·rust
Larcher13 小时前
🔥 告别抓瞎:用 Claude Code (cc) 优雅接手与维护已有项目
javascript·机器学习·前端框架
JYeontu13 小时前
轮播图不够惊艳?试下这个立体卡片轮播图
前端·javascript·css