• 节流&防抖


    节流:wait时间内只能执行一次func

    防抖:触发后延迟wait秒调用func

    代码对比:(建议自己手敲一遍,不要养成直接cv的坏习惯)

    节流:

    其中的apply函数是   

    apply() 是 JavaScript 函数的一个方法,它用于调用函数并设置函数内部 this 关键字的指向。

    throttle() 函数中,func 是传入的需要防抖的函数,args 是该函数的参数列表。当节流函数执行时,会通过 apply() 方法调用传入的函数,并将 this 指向当前的上下文环境,同时将参数 args 传递给该函数。 

    节流函数通常运用在限制调用频率场景

    • 搜索框输入时的实时联想
    • 拖拽场景防止超高频次触发位置变动
    • 滚动场景监听scroll事件计算位置信息,比如判断是否到页面底部自动加载更多

    防抖:

    防抖函数通常运用在限制调用次数场景

    • 文本输入的验证,连续输入后验证一次即可
    • 防止鼠标迅速点击多次提交按钮
    • 监听 resize 事件计算尺寸信息
    1. //防抖
    2. function debounce(func, wait) {
    3. let timer = null;
    4. return function () {
    5. //检查是否存在定时器
    6. if (timer) {
    7. //清除定时器
    8. clearInterval(timer);
    9. timer = null;
    10. }
    11. let self = this;
    12. let args = arguments;//args 是用户函数的参数列表
    13. timer = setTimeout(function () {
    14. func.apply(self, args);//执行用户函数
    15. timer = null;//重置定时器
    16. }, wait)
    17. }
    18. }
    19. //节流
    20. //func是用户传入需要防抖的函数
    21. //wait是等待时间
    22. function throttle(func, wait=50) {
    23. let lastTime = 0;//上一次执行该函数的时间
    24. let timer = null;
    25. return function () {
    26. //如果存在定时器要先清除
    27. if (timer) {
    28. clearInterval(timer);
    29. timer = null;
    30. }
    31. let self = this;
    32. let args = arguments;
    33. let nowTime = +new Date();
    34. //剩余等待时间
    35. const remainWaitTime = wait - (nowTime - lastTime);
    36. if (remainWaitTime <= 0) {
    37. lastTime = nowTime;
    38. //apply() 是 JavaScript 函数的一个方法,它用于调用函数并设置函数内部 this 关键字的指向。
    39. func.apply(self, args);
    40. } else {
    41. //继续等待remainWaitTime再执行
    42. timer = setTimeout(function () {
    43. lastTime = +new Date();
    44. func.apply(self, args);
    45. timer = null;//重置定时器
    46. }, remainWaitTime)
    47. }
    48. }
    49. }

  • 相关阅读:
    济南瞪羚企业申报流程,瞪羚企业认定标准-
    在更一般意义上验算移位距离和假设
    【电动车优化调度】基于模型预测控制(MPC)的凸优化算法的电动车优化调度(Matlab代码实现)
    【iOS】——分类、扩展和关联对象
    visual studio Qt 开发环境中手动添加 Q_OBJECT 导致编译时出错的问题
    初识Node.js开发
    Talend 用Jave 处理数据转换
    穿越周期的强者:打造“第二招牌”是战略共性
    Flume工具详解
    开源的远程桌面软件RustDesk
  • 原文地址:https://blog.csdn.net/m0_62742402/article/details/133915715