• 节流&防抖


    节流: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. }

  • 相关阅读:
    vue模板语法上集
    阿里云交互式建模(DSW)的探索和踩坑
    前端设置env配置文件yaml/json格式 在项目中读取
    antd table表格支持多选框选择当前列,进行格式设置等
    Spring IOC 和 AOP
    网络安全框架和云安全参考架构介绍
    拼多多第二季度表现亮眼,“贪便宜”的你贡献了多少?
    第一章:最新版零基础学习 PYTHON 教程(第十节 - Python 语句中的 – Python 如果否则)
    [附源码]SSM计算机毕业设计中小学微课学习系统JAVA
    18C++之引用
  • 原文地址:https://blog.csdn.net/m0_62742402/article/details/133915715