vue中使用防抖节流

67 阅读2分钟

1.什么是防抖节流 函数防抖(debounce) 是指在一定时间内,在动作被连续频繁触发的情况下,动作只会被执行一次,也就是说当调用动作过n毫秒后,才会执行该动作,若在这n毫秒内又调用此动作则将重新计算执行时间,所以短时间内的连续动作永远只会触发一次。

函数节流 是指一定时间内执行的操作只执行一次,也就是说即预先设定一个执行周期,当调用动作的时刻大于等于执行周期则执行该动作,然后进入下一个新周期,一个比较形象的例子是如果将水龙头拧紧直到水是以水滴的形式流出,那你会发现每隔一段时间,就会有一滴水流出。

函数节流(throttle)与 函数防抖(debounce)都是为了限制函数的执行频次,以优化函数触发频率过高导致的响应速度跟不上触发频率,出现延迟,假死或卡顿的现象。

区别: 防抖是将多次执行变成最后一次执行;而节流是将多次执行变为每隔一段时间执行一次。

那么它们各自的使用场景有哪些呢? 防抖

短信验证码 提交表单 resize 事件 input 事件(当然也可以用节流,实现实时关键字查找) 节流

scroll 事件,单位时间后计算一次滚动位置 input 事件(上面提到过)

函数封装

防抖

export function _debounce(fn, delay) {

var delay = delay || 200;
var timer;
return function () {
    var th = this;
    var args = arguments;
    if (timer) {
        clearTimeout(timer);
    }
    timer = setTimeout(function () {
        timer = null;
        fn.apply(th, args);
    }, delay);
};

}

节流

export function _throttle(fn, interval) {

var last;
var timer;
var interval = interval || 200;
return function () {
    var th = this;
    var args = arguments;
    var now = +new Date();
    if (last && now - last < interval) {
        clearTimeout(timer);
        timer = setTimeout(function () {
            last = now;
            fn.apply(th, args);
        }, interval);
    } else {
        last = now;
        fn.apply(th, args);
    }
}

}

在需要使用的组件中引用

import { _debounce } from "..."

使用

 methods: {
    // 改变场数
    changefield: _debounce(function(_type, index, item) {
        // do something ...
    }, 200)
  }