防抖和节流是优化高频事件的两种手段。防抖通过延迟执行,仅在事件停止触发后运行一次,适用于搜索输入等场景;节流则保证函数在设定时间间隔内最多执行一次,适合滚动监听、鼠标移动等持续触发的场景。两者核心区别在于执行时机与频率控制方式不同,合理使用可显著提升性能。

在 JavaScript 开发中,频繁触发的事件(如窗口滚动、窗口缩放、输入框输入、鼠标移动等)容易造成性能问题。防抖(debounce)和节流(throttle)是两种常用的优化手段,用于控制函数执行频率,减少不必要的调用,提升页面响应速度与性能。
防抖的核心思想是:当事件被触发后,设置一个延迟时间,若在这个时间内事件再次被触发,则重新计时。只有当事件停止触发超过设定的时间后,才会真正执行一次回调函数。
适用于搜索建议、窗口大小调整、按钮重复点击等场景。
示例:实现一个简单的防抖函数
function debounce(func, wait) {
let timeout;
return function executedFunction(...args) {
const later = () => {
clearTimeout(timeout);
func.apply(this, args);
};
clearTimeout(timeout);
timeout = setTimeout(later, wait);
};
}
使用方式:
立即学习“Java免费学习笔记(深入)”;
const debouncedSearch = debounce(() => {
console.log('执行搜索');
}, 300);
绑定到输入框事件即可避免每次输入都发起请求。
节流的策略是:无论事件触发多频繁,确保函数在指定的时间间隔内最多执行一次。比如每 100ms 最多执行一次处理函数。
适合用于鼠标移动、滚动加载、拖拽等高频但不需要实时响应的场景。
示例:实现一个基于时间戳的节流函数
function throttle(func, limit) {
let inThrottle;
return function(...args) {
if (!inThrottle) {
func.apply(this, args);
inThrottle = true;
setTimeout(() => inThrottle = false, limit);
}
};
}
使用方式:
立即学习“Java免费学习笔记(深入)”;
window.addEventListener('scroll', throttle(() => {
console.log('滚动中,但不会太频繁');
}, 100));
合理选择防抖或节流,能显著降低函数调用次数,减轻浏览器负担,提升用户体验。基本上就这些,不复杂但容易忽略细节。
以上就是防抖与节流实现_javascript性能优化的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号