使用节流控制频率,避免布局重排,启用passive监听器,优先采用Intersection Observer实现懒加载,可显著提升滚动性能。

滚动事件在网页交互中很常见,但处理不当容易导致页面卡顿。关键在于减少事件触发频率和避免重排重绘。以下是几种有效优化方式。
使用节流(Throttle)控制执行频率
滚动时事件会高频触发,直接在回调中执行复杂操作会影响性能。通过节流限制函数执行间隔,确保一定时间内只运行一次。
例如,使用 Lodash 的 throttle 或手动实现:
function throttle(func, delay) {let inThrottle;
return function() {
if (!inThrottle) {
func.apply(this, arguments);
inThrottle = true;
setTimeout(() => inThrottle = false, delay);
}
};
}
window.addEventListener('scroll', throttle(() => {
console.log('滚动中');
}, 100));
避免在滚动中修改布局
在 scroll 回调里读写 DOM 属性可能引发强制同步重排,拖慢渲染速度。应尽量减少访问像 offsetTop、clientHeight 这类布局属性。
立即学习“Java免费学习笔记(深入)”;
建议:
漂亮的企业网站。NET2.0出来了, 本次升级修改如下: 1、优化了3层结构。 2、优化了后台管理代码,增强了安全性能。 3、增加了系统名称及关键字管理。 4、增加了系统错误日志记录,自动生成Systemlog.log日志文件。 备注:本系统采用ASP.NET 2.O+ACCESS开发,请调试的朋友安装.NET2.0运行环境! 网站内容 网站栏目包括 首页|企业简介|新闻中心|产品展示|公司展示|
- 将布局计算提取到 scroll 外,用变量缓存值
- 使用 getBoundingClientRect() 一次性获取元素位置
- 延迟非关键操作到 scroll 结束后处理
利用 passive event listeners 提升响应速度
某些浏览器默认会等待 scroll 事件回调执行完才滚动,造成卡顿。设置 passive: true 可让浏览器提前滚动,提升流畅度。
尤其适用于只监听而不调用 preventDefault() 的场景:
window.addEventListener('scroll', () => {// 仅监听,不阻止默认行为
}, { passive: true });
考虑使用 Intersection Observer 替代 scroll 监听
如果目的是检测元素是否进入视口(如懒加载),推荐使用 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[data-src]').forEach(img => {
observer.observe(img);
});
基本上就这些。合理使用节流、避免布局抖动、启用 passive 和优先选择 IntersectionObserver,能显著提升滚动体验。不复杂但容易忽略细节。










