JavaScript 性能优化实战研讨
核心优化方向
- 执行效率:减少主线程阻塞
- 内存管理:避免泄漏和过度消耗
- 加载性能:加快解析与执行速度
- 渲染优化:减少布局重排与重绘
🔥 关键优化策略与代码示例
1️⃣ 减少重排(Reflow)与重绘(Repaint)
// 避免逐行修改样式
const el = document.getElementById('box');// ❌ 错误方式(多次重排)
el.style.width = '100px';
el.style.height = '50px';
el.style.margin = '10px';// ✅ 正确方式(单次重排)
el.style.cssText = 'width:100px; height:50px; margin:10px;';// ✅ 使用class切换
el.classList.add('active-style');
2️⃣ 事件委托优化
// ❌ 每个按钮绑定监听器
document.querySelectorAll('.btn').forEach(btn => {btn.addEventListener('click', handleClick);
});// ✅ 事件委托(单个监听器)
document.body.addEventListener('click', e => {if (e.target.classList.contains('btn')) {handleClick(e);}
});
3️⃣ 防抖与节流
// 防抖(最后一次触发后执行)
function debounce(func, delay = 300) {let timer;return (...args) => {clearTimeout(timer);timer = setTimeout(() => func.apply(this, args), delay);};
}// 节流(固定间隔执行)
function throttle(func, limit = 300) {let lastRun;return (...args) => {if (!lastRun) {func.apply(this, args);lastRun = Date.now();} else {clearTimeout(timer);const timer = setTimeout(() => {if (Date.now() - lastRun >= limit) {func.apply(this, args);lastRun = Date.now();}}, limit - (Date.now() - lastRun));}};
}// 使用示例
window.addEventListener('resize', throttle(calculateLayout, 200));
4️⃣ 异步任务优化
// ✅ 使用 requestAnimationFrame 替代 setTimeout
function animate() {// 动画逻辑requestAnimationFrame(animate);
}
requestAnimationFrame(animate);// ✅ Web Workers 处理 CPU 密集型任务
const worker = new Worker('compute.js');
worker.postMessage(data);
worker.onmessage = e => processResult(e.data);
5️⃣ 内存管理技巧
// 及时清除引用
let largeData = getHugeData();function process() {// 使用数据...
}// 使用后立即释放
process();
largeData = null; // 解除引用// 避免闭包内存泄漏
function createHeavyClosure() {const bigObj = new Array(1000000);return () => {// ❌ 错误:闭包捕获bigObjconsole.log(bigObj.length); // ✅ 解决方案:只保留需要的数据const len = bigObj.length;return len;};
}
6️⃣ 循环优化
// ❌ 低效循环
for (let i = 0; i < arr.length; i++) { ... }// ✅ 优化方案
// 1. 缓存长度
const len = arr.length;
for (let i = 0; i < len; i++) { ... }// 2. 倒序循环(减少比较)
for (let i = arr.length; i--; ) { ... }// 3. 使用 while 循环
let i = arr.length;
while (i--) { ... }
7️⃣ DOM 操作优化
// ❌ 多次操作DOM
for (let i = 0; i < 100; i++) {const div = document.createElement('div');document.body.appendChild(div);
}// ✅ 使用文档片段(DocumentFragment)
const fragment = document.createDocumentFragment();
for (let i = 0; i < 100; i++) {const div = document.createElement('div');fragment.appendChild(div);
}
document.body.appendChild(fragment);
📊 性能检测工具
-
Chrome DevTools
- Performance 面板:分析运行时性能
- Memory 面板:检测内存泄漏
- Coverage 面板:查看代码使用率
-
Lighthouse:自动化性能评分
-
WebPageTest:多地点性能测试
🚀 高级优化技术
// 1. 使用 IntersectionObserver 实现懒加载
const observer = new IntersectionObserver(entries => {entries.forEach(entry => {if (entry.isIntersecting) {const img = entry.target;img.src = img.dataset.src;observer.unobserve(img);}});
});document.querySelectorAll('img.lazy').forEach(img => {observer.observe(img);
});// 2. 虚拟滚动(Virtual Scrolling)
// 仅渲染可视区域内容,示例使用 react-window 库
import { FixedSizeList } from 'react-window';const Row = ({ index, style }) => (<div style={style}>Row {index}</div>
);const VirtualList = () => (<FixedSizeListheight={400}width={300}itemCount={1000}itemSize={35}>{Row}</FixedSizeList>
);
✅ 最佳实践清单
- 使用
textContent
代替innerHTML
- 用 CSS transform 替代 top/left 动画
- 避免同步布局(强制同步重排)
- 使用 WebAssembly 处理密集型计算
- 代码分割(Webpack SplitChunks)
- 预加载关键资源:
<link rel="preload">
- 启用 HTTP/2 和 Brotli 压缩
- 使用 Web Vitals 监控核心性能指标
关键指标:FCP (首次内容绘制) < 1.5s,TTI (可交互时间) < 5s
通过结合这些策略和现代浏览器API,可显著提升JavaScript应用的运行效率和用户体验。性能优化应持续进行,建议建立性能监控体系并定期进行优化迭代。
相关文章:
JavaScript 性能优化实战研讨
核心优化方向 执行效率:减少主线程阻塞内存管理:避免泄漏和过度消耗加载性能:加快解析与执行速度渲染优化:减少布局重排与重绘 🔥 关键优化策略与代码示例 1️⃣ 减少重排(Reflow)与重绘(Repaint) // 避免逐行修改样…...

有机黑鸡蛋与普通鸡蛋:差异剖析与选购指南
在我们的日常饮食结构里,鸡蛋始终占据着不可或缺的位置,是人们获取营养的重要来源。如今,市场上鸡蛋种类丰富,除了常见的普通鸡蛋,有机黑鸡蛋也逐渐崭露头角,其价格通常略高于普通鸡蛋。这两者究竟存在哪些…...

CTFHub-RCE 命令注入-无过滤
观察源代码 判断是Windows还是Linux 源代码中有 ping -c 4 说明是Linux 查看有哪些文件 127.0.0.1|ls 发现除了index.php文件外,还存在一个可疑的文件 打开flag文件 我们尝试打开这个文件 127.0.0.1|cat 19492844826916.php 可是发现 文本内容显示不出来&…...
spring IOC控制反转
控制反转,将对象的创建进行反转,常规情况下,对象都是开发者手动创建的,使用 loC 开发者不再需要创建对象,而是由IOC容器根据需求自动创建项目所需要的对象 不用IOC,所有对象IOC开发者自己创建使用IOC&…...
hot100 -- 1.哈希系列
1.两数之和 题目: 给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。 题解: 方法1:暴力求解 def get_two_sum(nums, target):for i in range(len(nums)):for j in range(i1, len(nums)):if nums[i] nums[j…...

leetcode hot100刷题日记——31.二叉树的直径
二叉树直径详解 题目描述对直径的理解解答:dfs小TIPS 题目描述 对直径的理解 实际上,二叉树的任意一条路径均可以被看作由某个节点为起点,从其左儿子和右儿子向下遍历的路径拼接得到。 那我们找二叉树的直径(最大路径)…...

行为型:解释器模式
目录 1、核心思想 2、实现方式 2.1 模式结构 2.2 实现案例 3、优缺点分析 4、适用场景 5、注意事项 1、核心思想 目的:针对某种语言并基于其语法特征创建一系列的表达式类(包括终极表达式与非终极表达式),利用树结构模式…...
逻辑回归详解:从原理到实践
在机器学习的广阔领域中,逻辑回归(Logistic Regression)虽名为 “回归”,实则是一种用于解决二分类(0 或 1)问题的有监督学习算法。它凭借简单易懂的原理、高效的计算性能以及出色的解释性,在数…...
FastAPI集成APsecheduler的BackgroundScheduler+mongodb(精简)
项目架构: FastAPI(folder) >app(folder) >core(folder) >models(folder) >routers(folder) >utils(folder) main.py(file) 1 utils文件夹下新建schedulers.py from apscheduler.schedulers.background import BackgroundScheduler from apschedu…...
本地部署FreeGPT+内网穿透公网远程访问,搞定ChatGPT外网访问难题
FreeGPT是一个基于GPT 3.5/4的ChatGPT聊天网页用户界面,提供了一个开放的聊天界面,开箱即用。ChatGPT是非常热门的,但访问体验一直不太理想。为了解决这一问题,出现了各类方法和工具,其中FreeGPT是一款非常实用的…...

linux 1.0.3
挂载 这个虚拟机啥时候都能挂起 会有一个这个东东 选择连接虚拟机,然后就连到linux了 这有两个键,一个是和主机连接一个是和虚拟机连接 先把U盘拔掉 原本是没有这个盘的,但是插上去之后,电脑创建了一个虚拟的盘 也就是图中的F…...
基于RK3588的智慧农场系统开发|RS485总线|华为云IOT|node-red|MQTT
一、硬件连接流程 本次采用的是 总线型拓扑:所有设备并联到两根 RS485 总线上(A 和 B-) 二、通信协议配置 1. 主从通信模式 RS485 是半双工:同一时间只能有一个设备发送数据主从架构:通常一个主设备(…...
解锁程序人生学习成长密码,从目标设定开始
解锁程序人生学习成长密码,从目标设定开始 关键词:程序员成长、目标设定、学习路径、技能提升、职业规划、刻意练习、反馈机制 摘要:本文深入探讨程序员如何通过科学的目标设定方法实现职业成长。文章从目标设定的重要性出发,详细介绍了SMART原则、OKR方法等技术,并结合程…...
简单cnn
数据增强 在图像数据预处理环节,为提升数据多样性,可采用数据增强(数据增广)策略。该策略通常不改变单次训练的样本总数,而是通过对现有图像进行多样化变换,使每次训练输入的样本呈现更丰富的形态差异&…...

C#集合循环删除某些行
你想要在遍历集合(例如List)的同时删除某些元素时,直接在循环中删除元素可能会导致问题,因为这可能会改变集合的大小和导致索引问题; 可以用for循环的倒序来删除; 如果要删除满足特定条件的所有元素&…...
相机定屏问题分析四:【cameraserver 最大request buffer超标】后置视频模式预览定屏闪退至桌面
【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:相机定屏问题分析三:【配流ConfigStream失败】外屏打开相机视频照片人像来回切换后,相机页面卡死,点击没反应9055522 这一篇我们开始讲: 相机定屏问题分析四:【cameraserver 最大request buffer超…...

【Linux 学习计划】-- 进程地址空间
目录 进程地址的引入 进程地址空间基础原理 区域划分的本质 如何理解进程地址空间 越界访问的本质 进一步理解写时拷贝 重谈 fork 返回值 结语 进程地址的引入 我们先来看一段代码: 首先我们可以看到,父进程和子进程是可以同时可以看到一个变量…...
告别重复 - Ansible 配置管理入门与核心价值
告别重复 - Ansible 配置管理入门与核心价值 还记得我们在 SRE 基础系列中反复强调的“减少琐事 (Toil)”和“拥抱自动化”吗?想象一下这些场景: 你需要部署一个新的 Web 服务集群,每台服务器都需要安装 Nginx、配置防火墙规则、同步 Web 内容、启动服务……手动操作不仅耗时…...
3D Gaussian splatting 04: 代码阅读-提取相机位姿和稀疏点云
目录 3D Gaussian splatting 01: 环境搭建3D Gaussian splatting 02: 快速评估3D Gaussian splatting 03: 用户数据训练和结果查看3D Gaussian splatting 04: 代码阅读-提取相机位姿和稀疏点云3D Gaussian splatting 05: 代码阅读-训练整体流程3D Gaussian splatting 06: 代码…...

CTFHub-RCE 命令注入-过滤空格
观察源代码 代码里面可以发现过滤了空格 判断是Windows还是Linux 源代码中有 ping -c 4 说明是Linux 查看有哪些文件 127.0.0.1|ls 打开flag文件 我们尝试将空格转义打开这个文件 利用 ${IFS} 127.0.0.1|cat${IFS}flag_195671031713417.php 可是发现 文本内容显示不出来&…...
卫生间改造翻新怎么选产品?我在瑞尔特找到了解决方案
在一场打掉重来的卫生间翻新改造中,最令人头疼的,从来都不是瓷砖、吊顶这类“看得见”的工序,而是那些每天都在用、但选错一次就要懊悔好多年的卫浴产品。从功能到体验,从老人适配到美学搭配,这事真不是买个贵的就够了…...
C++ list数据删除、list数据访问、list反转链表、list数据排序
list数据删除,代码见下 #include<iostream> #include<list>using namespace std;void printList(const list<int>& l) {for (list<int>::const_iterator it l.begin(); it ! l.end(); it) {cout << *it << " "…...

Express教程【002】:Express监听GET和POST请求
文章目录 2、监听post和get请求2.1 监听GET请求2.2 监听POST请求 2、监听post和get请求 创建02-app.js文件。 2.1 监听GET请求 1️⃣通过app.get()方法,可以监听客户端的GET请求,具体的语法格式如下: // 1、导入express const express req…...
mysql安装教程--笔记
一、Windows 系统安装 方法1:使用 MySQL Installer(推荐) 1. 下载安装包 访问 MySQL 官网下载页面,选择 MySQL Installer for Windows。 2. 运行安装程序 双击下载的 .msi 文件,选择安装类型: ◦ Developer…...
C++ 观察者模式:设计与实现详解
一、引言 在现代软件开发中,组件间的交互与通信是系统设计的核心挑战之一。观察者模式(Observer Pattern)作为一种行为设计模式,提供了一种优雅的解决方案,用于实现对象间的一对多依赖关系。本文将深入探讨 C++ 中观察者模式的设计理念、实现方式及其应用场景。 二、观察…...

【PostgreSQL 03】PostGIS空间数据深度实战:从地图服务到智慧城市
PostGIS空间数据深度实战:从地图服务到智慧城市 关键词 PostGIS, 空间数据库, 地理信息系统, GIS, 空间查询, 地理分析, 位置服务, 智慧城市, 空间索引, 坐标系统 摘要 PostGIS是PostgreSQL的空间数据扩展,它将普通的关系数据库转变为强大的地理信息系统…...

HIT-csapp大作业:程序人生-HELLO‘s P2P
计算机系统 大作业 题 目 程序人生-Hello’s P2P 专 业 计算学部 学 号 2023111813 班 级 23L0518 学 生 鲁永哲 指 导 教 师 史先俊 计…...

深入探讨redis:主从复制
前言 如果某个服务器程序,只部署在一个物理服务器上就可能会面临一下问题(单点问题) 可用性问题,如果这个机器挂了,那么对应的客户端服务也相继断开性能/支持的并发量有限 所以为了解决这些问题,就要引入分布式系统,…...

帕金森常见情况解读
一、身体出现的异常节奏 帕金森会让身体原本协调的 “舞步” 出现错乱。它是一种影响身体行动能力的状况,随着时间推进,就像老旧的时钟,齿轮转动不再顺畅,使得身体各个部位的配合逐渐失衡,打乱日常行动的节奏。 …...

清华大学发Nature!光学工程+神经网络创新结合
2025深度学习发论文&模型涨点之——光学工程神经网络 清华大学的一项开创性研究成果在《Nature》上发表,为光学神经网络的发展注入了强劲动力。该研究团队巧妙地提出了一种全前向模式(Fully Forward Mode,FFM)的训练方法&…...