javascript 性能优化实例一则

减少重绘和回流

在JavaScript中,频繁操作DOM会导致浏览器重绘和回流,影响性能。可以通过合并DOM操作或使用文档片段(DocumentFragment)来减少重绘和回流次数。

复制代码
// 低效方式:多次操作DOM
for (let i = 0; i < 100; i++) {
  document.body.appendChild(document.createElement('div'));
}

// 高效方式:使用文档片段
const fragment = document.createDocumentFragment();
for (let i = 0; i < 100; i++) {
  fragment.appendChild(document.createElement('div'));
}
document.body.appendChild(fragment);

使用事件委托

事件委托利用事件冒泡机制,将事件处理程序绑定到父元素而非每个子元素,减少内存消耗和事件绑定时间。

复制代码
// 低效方式:为每个子元素绑定事件
document.querySelectorAll('li').forEach(li => {
  li.addEventListener('click', () => {
    console.log(li.textContent);
  });
});

// 高效方式:事件委托
document.querySelector('ul').addEventListener('click', (e) => {
  if (e.target.tagName === 'LI') {
    console.log(e.target.textContent);
  }
});

避免频繁操作样式

直接修改元素的style属性会导致多次回流。可以通过添加或移除CSS类名来批量修改样式。

复制代码
// 低效方式:直接修改style
element.style.width = '100px';
element.style.height = '200px';
element.style.backgroundColor = 'red';

// 高效方式:使用CSS类名
element.classList.add('active');

使用节流和防抖

对于频繁触发的事件(如scroll、resize),使用节流(throttle)或防抖(debounce)技术减少事件处理函数的执行频率。

复制代码
// 防抖实现
function debounce(func, delay) {
  let timer;
  return function() {
    clearTimeout(timer);
    timer = setTimeout(() => func.apply(this, arguments), delay);
  };
}

window.addEventListener('resize', debounce(() => {
  console.log('Resize event handled');
}, 200));

// 节流实现
function throttle(func, limit) {
  let inThrottle;
  return function() {
    if (!inThrottle) {
      func.apply(this, arguments);
      inThrottle = true;
      setTimeout(() => inThrottle = false, limit);
    }
  };
}

window.addEventListener('scroll', throttle(() => {
  console.log('Scroll event handled');
}, 100));

优化循环性能

在循环中避免重复计算或访问DOM,可以通过缓存变量或减少循环次数提升性能。

复制代码
// 低效方式:重复访问DOM
for (let i = 0; i < document.querySelectorAll('div').length; i++) {
  console.log(document.querySelectorAll('div')[i].textContent);
}

// 高效方式:缓存DOM查询结果
const divs = document.querySelectorAll('div');
const length = divs.length;
for (let i = 0; i < length; i++) {
  console.log(divs[i].textContent);
}

使用Web Workers处理耗时任务

将耗时任务(如大数据处理)放到Web Worker中执行,避免阻塞主线程。

复制代码
// 主线程代码
const worker = new Worker('worker.js');
worker.postMessage({ data: largeArray });
worker.onmessage = (e) => {
  console.log('Result:', e.data);
};

// worker.js
self.onmessage = (e) => {
  const result = e.data.data.map(processData);
  self.postMessage(result);
};

合理使用缓存

对于重复计算或请求的数据,使用缓存机制避免重复处理。

复制代码
const cache = {};
function expensiveOperation(key) {
  if (cache[key]) {
    return cache[key];
  }
  const result = /* 复杂计算 */;
  cache[key] = result;
  return result;
}
相关推荐
嵌入式-老费5 分钟前
自己动手写深度学习框架(快速学习python和关联库)
开发语言·python·学习
ctgu9012 分钟前
PyQt5(八):ui设置为可以手动随意拉伸功能
开发语言·qt·ui
CVer儿20 分钟前
libtorch ITK 部署 nnUNetV2 模型
开发语言
asyxchenchong88828 分钟前
OpenLCA、GREET、R语言的生命周期评价方法、模型构建
开发语言·r语言
小杨梅君39 分钟前
探索现代 CSS 色彩:从 HSL 到 OKLCH,打造动态色阶
前端·javascript·css
没有梦想的咸鱼185-1037-166340 分钟前
【生命周期评价(LCA)】基于OpenLCA、GREET、R语言的生命周期评价方法、模型构建
开发语言·数据分析·r语言
刺客_Andy41 分钟前
React 第五十一节 Router中useOutletContext的使用详解及注意事项
前端·javascript·react.js
你说啥名字好呢1 小时前
【React Fiber的重要属性】
javascript·react.js·ecmascript
程序猿20231 小时前
Python每日一练---第三天:删除有序数组中的重复项
开发语言·python
一只游鱼1 小时前
Springboot+BannerBanner(启动横幅)
java·开发语言·数据库