防抖节流函数的 封装

为什么要引入防抖节流

当一个函数被频繁触发、调用时,会严重加重浏览器的负担,造成浏览器卡顿的现象。因此引入防抖、节流来限制函数的执行频次,以优化函数触发频率过高引起的响应速度跟不上触发频率,出现延迟、假死或卡顿的现象。

防抖 debounce

当事件被频繁触发后,延迟n秒再执行该事件。如果n秒内再次触发,则重新计时

特点:停止触发n秒后,事件处理函数才会执行一次

场景:1、用户多次点击搜索、登录、导出按钮; 2、搜索框输入在输入完成之后才执行查询的请求;3、窗口Resize事件在调整完之后再计算窗口大小,防止重复触发回流重绘

作用:采用防抖策略,可以有效减少请求次数,节约请求资源

封装防抖函数:

<input id="input1" type="text">

const input1 = document.getElementById('input1')
function debounce(fn,delay){
	let timer = null
	return function (...args){
		//n秒内重复触发 计时器重新开始计时
		if(timer) clearTimeout(timer)
		timer = setTimeout(()=>{
			fn.apply(this,args)
			timer = null
		},delay)
	}
}
input1.addEventListener('keyup',debounce(()=>{
	console.log(input1.value)
},500))
节流 throttle

当事件被持续触发,每隔n秒执行事件一次

特点:按照一定频率,“匀速等距离”触发事件处理函数

场景:1、鼠标连续移动不断触发某事件/拖拽元素,要拿到元素被拖拽过程中移动的位置;2、搜索框输入联想的功能 3、懒加载监听滚动条的位置,但不必要每次滚动都监听

作用:采用节流策略降低触发频率,节约cpu资源

封装节流函数:

<span id="div1" draggable="true" style=“background:pink”>拖拽元素</span>

const span1 = document.getElementById('span1')
function throttle (fn,delay=100){
	let timer = null
	return function(...args){
		//n秒内再次触发 直接返回,忽略本次触发事件
		if(timer) return
		timer = setTimeout(()=>{
			fn.apply(this,args)
			timer = null
		},delay)
	}
}
span1.addEventListener('drag',throttle(e)=>{
	console.log(e.offsetX,e.offsetY)
},200)
两者区别比较

事件频发触发,防抖只能保证停止触发n秒后执行一次,前面的多次触发都会被忽略;而节流是指事件频繁触发时,按照一定的频率有选择性的执行一部分事件

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
防抖节流是两种常用的函数优化技术,可以用来限制函数的执行频率,提高性能和用户体验。 防抖函数的作用是在短时间内连续触发同一事件时,只执行最后一次操作,而忽略之前的操作。可以用于处理频繁触发的事件,比如窗口大小改变、输入框输入等。 下面是一个简单的防抖函数封装示例: ```javascript function debounce(func, delay) { let timer = null; return function(...args) { clearTimeout(timer); timer = setTimeout(() => { func.apply(this, args); }, delay); }; } ``` 使用方式示例: ```javascript function handleInput() { // 处理输入事件 } const debouncedHandleInput = debounce(handleInput, 300); // 创建防抖函数 inputElement.addEventListener('input', debouncedHandleInput); // 绑定防抖函数到输入框的输入事件 ``` 节流函数的作用是在一定时间间隔内只执行一次操作,可以用于处理高频率触发的事件,比如滚动事件、鼠标移动事件等。 下面是一个简单的节流函数封装示例: ```javascript function throttle(func, delay) { let timer = null; return function(...args) { if (timer) return; timer = setTimeout(() => { func.apply(this, args); timer = null; }, delay); }; } ``` 使用方式示例: ```javascript function handleScroll() { // 处理滚动事件 } const throttledHandleScroll = throttle(handleScroll, 300); // 创建节流函数 window.addEventListener('scroll', throttledHandleScroll); // 绑定节流函数到窗口的滚动事件 ``` 以上是基本的防抖节流函数封装示例,可以根据实际需求进行调整和扩展。希望能对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值