繁体   English   中英

我如何正确地去抖动 mapDispatchToProps 或 redux 动作?

[英]How i can correctly debounce mapDispatchToProps or redux action?

我有 redux 动作:

export const setSearchText = payload => ({
  type: SEARCH_ACTION,
  payload,
});

并遵循 mapDispatchToPros:

const mapDispatchToProps = dispatch => ({
  onChange: (...args) => setSearchText(...args),
});

我怎样才能去抖动?

const mapDispatchToProps = dispatch => ({
  onChange: (...args) =>{
    setTimeout(()=>dispatch(setSearchText(...args)),1000);
  }
});

这里的去抖时间设置为 1 秒

希望这段代码有效

  onChange: (...args) => debounce(() => dispatch(setSearchText(...args)), 500)

这是去抖 function。

const debounce = (func, wait) => {
  let timeout;
  return function() {
    const context = this;
    const args = arguments;
    const later = function() {
      timeout = null;
      func.apply(context, args);
    };
    clearTimeout(timeout);
    timeout = setTimeout(later, wait);
  };
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM