【前端面经】快手二面:节流和防抖知道吗?

简介: 【前端面经】快手二面:节流和防抖知道吗?

面试官:节流与防抖,说说两者各自适用场景?

回答:面试官,在前端开发中,节流(Throttle)和防抖(Debounce)是两种常用的优化高频率执行JavaScript代码的技术。我将分别阐述它们的概念、适用场景,并给出代码示例。


首先解释一下防抖(Debounce):

防抖是指在事件被触发后延迟一段时间后再执行回调,如果在这段延迟时间内事件又被触发,则重新计算延迟时间。 防抖适用于那些对连续的事件响应不是必须且不影响用户体验的情况,例如搜索输入框输入时的自动补全功能。下面是一个简单的防抖函数实现:

function debounce(func, wait) {
  let timeout;
  return function() {
    const context = this;
    const args = arguments;
    clearTimeout(timeout);
    timeout = setTimeout(function(){
      func.apply(context, args);
    }, wait);
  };
}

// 使用例子
const handleSearch = debounce(function() {
  // 触发搜索请求逻辑
}, 500);

// 监听输入框的输入事件
input.addEventListener('input', handleSearch);

然后是节流(Throttle):

节流是指在一段时间内,不管事件触发了多少次,只执行一次回调。 节流适用于诸如resize、scroll等性能敏感的事件中,以避免频繁的回调执行导致的性能问题。下面是一个简单的节流函数实现:

function throttle(func, wait) {
  let timeout;
  return function() {
    const context = this;
    const args = arguments;
    if (!timeout) {
      timeout = setTimeout(function(){
        timeout = null;
        func.apply(context, args);
      }, wait);
    }
  };
}

// 使用例子
const handleResize = throttle(function() {
  // 处理resize逻辑,例如重新计算布局
}, 200);

// 监听窗口的resize事件
window.addEventListener('resize', handleResize);

此外,lodash这个工具库提供了现成的_.debounce_.throttle方法,实际开发中可以直接使用,通常来说它们的实现会更完备和健壮。

相关文章
|
4月前
|
前端开发 JavaScript API
|
1月前
|
前端开发 UED 开发者
颠覆你的前端知识:防抖与节流的区别及实战解析!
【8月更文挑战第23天】在Web前端开发中,处理用户界面交互产生的事件可能会影响性能。为此,我们有两种优化方法:防抖(debounce)和节流(throttle)。防抖确保函数仅在事件停止触发一段时间后执行一次,适用于如搜索自动补全场景。而节流则确保函数按固定时间间隔执行,不管用户操作频率如何。本篇技术博客将深入解析两者差异并提供示例代码,帮助开发者更好地理解和应用这些技巧以提升应用性能和用户体验。
61 0
|
1天前
|
缓存 边缘计算 前端开发
关于前端性能优化问题,认识网页加载过程和防抖节流
该文章详细探讨了前端性能优化的方法,包括理解网页加载过程、实施防抖和节流技术来提升用户体验和性能。
|
2月前
|
缓存 开发框架 前端开发
前端性能优化【前端必备】(含懒加载,手写防抖、节流等)
前端性能优化【前端必备】(含懒加载,手写防抖、节流等)
55 4
|
4月前
|
前端开发 JavaScript UED
【专栏】前端开发中,为解决用户操作引发的性能问题,常使用debounce(防抖)和throttle(节流)技术
【4月更文挑战第29天】前端开发中,为解决用户操作引发的性能问题,常使用debounce(防抖)和throttle(节流)技术。Debounce确保在一段时间内只执行最后一次事件触发的操作,减少不必要的执行,但有滞后性,适合搜索框实时搜索。Throttle则保证一定时间间隔内函数执行一次,保持固定频率,适用于滚动事件处理和窗口大小调整。两者可借助JavaScript或第三方库实现,需根据场景和需求选择并调整。正确使用能提升应用性能和用户体验。
37 1
|
4月前
|
前端开发 UED
【Web 前端】防抖与节流的区别
【4月更文挑战第22天】【Web 前端】防抖与节流的区别
|
4月前
|
前端开发
【前端学习】—函数防抖(十)
【前端学习】—函数防抖(十)
|
14天前
|
SpringCloudAlibaba JavaScript 前端开发
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
分布式组件、nacos注册配置中心、openfegin远程调用、网关gateway、ES6脚本语言规范、vue、elementUI
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
|
1月前
|
存储 前端开发 JavaScript
前端语言串讲 | 青训营笔记
前端语言串讲 | 青训营笔记
25 0
|
3月前
|
JSON 前端开发 JavaScript
前端Ajax、Axios和Fetch的用法和区别笔记
前端Ajax、Axios和Fetch的用法和区别笔记
71 2