JavaScript 防抖与节流

防抖:规定时间内没触发交互事件,才执行函数

	<el-input @input="debounce(fn, 1000)" />
	
	/**	防抖函数	
	 *	fn		执行方法
	 *	time	等待事件
	 */
	function debounce(fn, time) {
      let timer = null;
      return function () {
        clearTimeout(timer);
        timer = setTimeout(() => {
           fn();
        }, time);
      };
    }
    
    document.getElementById("box").addEventListener(
      "mousewheel",
      debounce(function () {
        console.log("执行");
      }, 1000)
    );



节流:规定时间内,交互多少次都只执行一次函数

	
	/**	节流函数	
	 *	fn		执行方法
	 *	time	冷却事件
	 */
	function throttle(fn, time) {
      let run = true;
      return function () {
        if (!run) return;
        run = false;
        setTimeout(() => {
          fn();
          run = true;
        }, time);
      };
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值