在vue中用防抖

在查询的请求中,每输入一个就会进行监听进行查询。那么我们需要做一个防抖节流的优化。

		<script>
			function getUserAction(e) {
			    console.log(e);
			    console.log('执行查询操作',+new Date());
			  };
			 
			function debounce(func, wait) {
				console.log('asdad')
			    var timeout;
			    return args => {
			      if (timeout) clearTimeout(timeout) 
			      timeout = setTimeout(func, wait);
			    }
			}
			
			document.getElementById('search').addEventListener('click',debounce(getUserAction, 1000))		
		</script>

但是,有一个关键的点。在把debounce(getUserAction, 1000)传递给addEventListener进行监听的时候,debounce(getUserAction, 1000) js会默认调用一次

所以在vue中使用是有点不同的

推荐使用loadsh.js这个工具包,里面有_debounce()方法

所以我们在vue中使用debounce,那就在mounted的时候先进行一次调用。然后把返回的函数传递给debounce进行调用。而我们在debounce中使用了闭包也是因为可以把函数进行缓存,并且进行循环调用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值