zoukankan      html  css  js  c++  java
  • _.debounce(fun)防抖动函数的用法

    _.debounce(func, [wait=0], [options=]),

    debounced(防抖动)函数,该函数会从上一次被调用后,延迟 wait 毫秒后调用 func 方法。 debounced(防抖动)函数提供一个 cancel 方法取消延迟的函数调用以及 flush 方法立即调用。 可以提供一个 options(选项) 对象决定如何调用 func 方法,options.leading 与|或 options.trailing 决定延迟前后如何触发(注:是 先调用后等待 还是 先等待后调用)。 func 调用时会传入最后一次提供给 debounced(防抖动)函数 的参数。 后续调用的 debounced(防抖动)函数返回是最后一次 func 调用的结果。

    参数

    1. func (Function): 要防抖动的函数。
    2. [wait=0] (number): 需要延迟的毫秒数。
    3. [options=] (Object): 选项对象。
    4. [options.leading=false] (boolean): 指定在延迟开始前调用。
    5. [options.maxWait] (number): 设置 func 允许被延迟的最大值。
    6. [options.trailing=true] (boolean): 指定在延迟结束后调用。

    返回

    (Function): 返回新的 debounced(防抖动)函数。

    例子

    // 避免窗口在变动时出现昂贵的计算开销。
    jQuery(window).on('resize', _.debounce(calculateLayout, 150));
     
    // 当点击时 `sendMail` 随后就被调用。
    jQuery(element).on('click', _.debounce(sendMail, 300, {
      'leading': true,
      'trailing': false
    }));
     
    // 确保 `batchLog` 调用1次之后,1秒内会被触发。
    var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });
    var source = new EventSource('/stream');
    jQuery(source).on('message', debounced);
     
    // 取消一个 trailing 的防抖动调用
    jQuery(window).on('popstate', debounced.cancel);

    用途:

    • 不使用debounce的情况:用户在连续输入文字时,会在每次输入时都会执行函数,有可能导致阻塞

                     或项目崩溃

                    $('.elements').on('input',(e)=>{console.log(e.target.value)})

    •  使用debouce的情况:用户在输入后的指定时间后才会执行函数

                     $('.elements').on('input',debounce((e)=>{console.log(e.target.value)},500))

  • 相关阅读:
    Django models通过DateTimeField保存到MySQL的时间的时区问题
    apache静态文件配置
    Python多线程学习
    Django filter中用contains 在mysql中的问题
    python:open/文件操作
    C++primer plus第六版课后编程题答案
    C++primer plus第六版课后编程题答案8.3
    C++primer plus第六版课后编程题答案8.2
    C++primer plus第六版课后编程题答案8.1
    C++primer plus第六版课后编程题答案7.10
  • 原文地址:https://www.cnblogs.com/maogu2/p/14452182.html
Copyright © 2011-2022 走看看