防抖和节流是为了防止监听时间或其他频繁触发的时间大量重复调用方法导致的性能浪费;
    简单的防抖:持续触发的事件过程中,当过了一段时间没有调用然后执行最后一次事件

    1. function debounce (fn, delay) {
    2. var timer;
    3. return function () {
    4. clearTimeout(timer);
    5. timer = setTimeout(() => {
    6. fn.call(this);
    7. }, delay)
    8. }
    9. }

    简单的节流:每隔多少时间调用一次事件

    1. function throttle (fn, delay) {
    2. var last = 0;
    3. return function () {
    4. let now = new Date().getTime();
    5. if (now - last > delay) {
    6. fn.call(this);
    7. last = now;
    8. }
    9. }
    10. }

    进阶版本防抖和节流
    https://blog.csdn.net/qin904495445/article/details/105786993

    1. function debounce (fn, delay, immediate) {
    2. let timer, res;
    3. let debounceFn = () => {
    4. if (timer) {
    5. clearTimer(timer);
    6. }
    7. if (immediate) {
    8. let now = !timer;
    9. timer = setTimeout(() => {
    10. timer = null;
    11. }, delay);
    12. if (now) {
    13. res = fn.call(this);
    14. }
    15. } else {
    16. timer = setTimeout(() => {
    17. res = fn.call(this);
    18. }, delay);
    19. }
    20. return res;
    21. }
    22. debounceFn.cancel = () => {
    23. clearTimeout(timer);
    24. timer = null;
    25. };
    26. return debounceFn;
    27. }

    https://blog.csdn.net/u012411231/article/details/106926053/
    https://www.cnblogs.com/songyao666/p/11415787.html