* 防抖函数:
debounce.js

let timeout = null;/** 肯定工夫内,只有最初一次操作,再过wait毫秒后才执行函数 *  * @param {Function} func 要执行的回调函数  * @param {Number} wait 延时的工夫 * @param {Boolean} immediate 是否立刻执行  * @return null */function debounce(func, wait = 500, immediate = false) {    // 革除定时器    if (timeout !== null) clearTimeout(timeout);    // 立刻执行,此类情况个别用不到    if (immediate) {        var callNow = !timeout;        timeout = setTimeout(function() {            timeout = null;        }, wait);        if (callNow) typeof func === 'function' && func();    } else {        // 设置定时器,当最初一次操作后,timeout不会再被革除,所以在延时wait毫秒后执行func回调办法        timeout = setTimeout(function() {            typeof func === 'function' && func();        }, wait);    }}export default debounce

-
节流函数

let timer, flag;/** * 节流原理:在肯定工夫内,只能触发一次 *  * @param {Function} func 要执行的回调函数  * @param {Number} wait 延时的工夫 * @param {Boolean} immediate 是否立刻执行 * @return null */function throttle(func, wait = 500, immediate = true) {    if (immediate) {        if (!flag) {            flag = true;            // 如果是立刻执行,则在wait毫秒内开始时执行            typeof func === 'function' && func();            timer = setTimeout(() => {                flag = false;            }, wait);        }    } else {        if (!flag) {            flag = true            // 如果是非立刻执行,则在wait毫秒内的完结处执行            timer = setTimeout(() => {                flag = false                typeof func === 'function' && func();            }, wait);        }    }};export default throttle

挂载全局 :
main.js

import throttle from './utils/throttle'Vue.prototype.$throttle = throttleimport debounce from './utils/debounce'Vue.prototype.$debounce = debounce