防抖节流,React失效写法

2020-10-15  本文已影响0人  Shiki_思清

防抖 lodash.debounce

直到经历了wait时间后,才执行函数
https://lodash.com/docs/4.17.15

import debounce from 'lodash/debounce';
constructor() {
  this.search = debounce(this.search, 500);
}
search = ()=> {
  ajax()
}

节流 lodash.throttle

每隔wait时间,执行一次函数
https://lodash.com/docs/4.17.15

import throttle from 'lodash/debounce';
constructor() {
  this.search = throttle(this.search, 500);
}
search = ()=> {
  ajax()
}

React 函数组件失效

每次render 都会导致debounce第一个参数(异步请求函数)更新,进而导致debounce的闭包失效

解决办法

通过useCallback保证传入debounce的第一个参数都是同一个函数

  const _onFinish = useCallback(values => {
    // 所有的异步请求
    getTotalStatistics({ ...baseParam, ...values });
    onFinishWithSchool(values);
    getSchoolListFn(values.inviteCode ? values.inviteCode : -1);
    //
  }, []);

  const onFinish = useCallback(
    debounce(_onFinish, 500, {
      leading: false,
      trailing: true,
    }),
    [_onFinish],
  );
上一篇 下一篇

猜你喜欢

热点阅读