javascript - js debounce函数有什么作用?这个函数有点看不懂,求解释?
高洛峰
高洛峰 2017-04-11 10:48:48
[JavaScript讨论组]

我如果把debounce函数去掉的话也是可以执行的?debounce函数在这里起了什么作用?
其中的变量immediate和timeout起到了什么作用,最好能通俗的解释下这个函数执行过程

    function debounce(func, wait = 20, immediate = true) {
      var timeout;
      return function() {
        var context = this, args = arguments;
        var later = function() {
          timeout = null;
          if (!immediate) func.apply(context, args);
        };
        var callNow = immediate && !timeout;
        clearTimeout(timeout);
        timeout = setTimeout(later, wait);
        if (callNow) func.apply(context, args);
      };
    };

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(1)
巴扎黑

防抖动,详细可以参考下面两个链接:
函数防抖与节流
实例解析防抖动(Debouncing)和节流阀(Throttling)

要学会善用搜索引擎。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号