js的防抖函数做了什么

用途

在开发中经常会遇到一些频繁的事件触发,如 onscrolloninput 之类的等事件。其实为了实现我们最终的功能,频繁触发的事件也许只有最后一次触发才是我们想要的,那么防抖函数就是干这个用途的。我们给它一个时间,告诉该函数,当前设定的时间内,只执行一次该函数,这样就减少了非必要事件的执行。

案例

现在我们设定一个案例来实践一下,比如说,我们在一次滚动事件,只想要滚动的最终值。

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style>
			#parent{
				height: 100px;
				border: 1px solid #ccc;
				overflow-y: scroll;
			}
			#child{
				height: 1000px;
			}
		</style>
	</head>
	<body>
		<div id="parent">
			<div id="child"></div>
		</div>
		<script>
			let $parent = document.querySelector("#parent");
			
			// 先要初始化一次,保证调用的过程中都是调用同一个闭包返回的函数
			let dobounceFn = dobounce(getScrollVal, 1000);
			
			$parent.onscroll = function(e){
				 dobounceFn($parent.scrollTop);
			}
			
			// 很明显,利用了防抖后,我们的功能函数每秒只会取一次值
			function getScrollVal(){
				console.log($parent.scrollTop)
			}
			
			// 防抖
			// 1、防止函数多次重复执行
			function dobounce(fn, wait){
				let timer = null;
				return function(){
					if(timer){
						clearTimeout(timer);
					}
					let context = this;
					let args = arguments;
					timer = setTimeout(function(){
						fn.call(context, args )
					}, wait)
				}
			}
		
		</script>
	</body>
</html>

代码分析

防抖的代码其实很简短,但是却用到了定时器、闭包,call,对于创造出这个函数的大佬真是佩服。

  • setTimeout 。这个就不用说了,一次性定时器
  • call。重新绑定 this 的指向 ,然后将内置返回函数的参数 arguments 传给 fn
  • 闭包。外层函数返回内层函数,内层函数使用了外层函数作用域中的变量,很经典。这里通过对外层函数中的 timer 进行重复利用,实现清除 wait时间内的所有非最后一次事件触发;
	/**
	* 防抖函数 
	* @param { Function } fn 
	* @param { Number } wait 
	*/
	function dobounce(fn, wait){
		let timer = null;
		return function(){
			if(timer){
				clearTimeout(timer);
			}
			let context = this;
			let args = arguments;
			timer = setTimeout(function(){
				fn.call(context, args )
			}, wait)
		}
	}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值