React中使用usePrevious的意义是什么,为啥要用它

usePrevious钩子

c 复制代码
export function usePrevious<T>(value: T): T | undefined {
  const ref = useRef<T>();

  useEffect(() => {
    ref.current = value;
  }, [value]);

  return ref.current;
}

注:更多好用的性能钩子网站推荐:https://react-hooks-library.vercel.app/core/usePrevious

原因

usePrevious 是一个自定义 Hook,用于记录上一次的状态,以便在下一次渲染时进行比较。使用 usePrevious 可以提升性能,并确保在每次渲染时都有上一次的状态值可供比较。这对于需要比较前后值的场景非常有用,例如图表的更新和事件监听器的添加。

举例说明

c 复制代码
  // 使用 usePrevious 钩子函数来记录上一次的 option 和 onClick 值
  const prevOption = usePrevious(option);
  const prevClickEvent = usePrevious(onClick);
    useEffect(() => {
      // ...省略部分逻辑   
      let chartInstance: ECharts | null = null;
      // 如果 option 或 onClick 值发生变化,则重新渲染
      try {
        if (!isDeepEqual(prevOption, option, ["formatter"])) {
          chartInstance.setOption(option);
        }
        if (onClick && typeof onClick === "function" && onClick !== prevClickEvent) {
          chartInstance.on("click", onClick);
        }
      } catch (error) {
        chartInstance && chartInstance.dispose();
      }
    }
  }, [option, onClick, prevOption, prevClickEvent]);

如上面代码,prevOption 和 prevClickEvent 使用 usePrevious 自定义 Hook 来存储前一个值的变量,作用是比较当前的 option 和 onClick 值与上一次的值是否相等。如果相等,则表示没有发生改变,不需要更新图表。通过比较前后值,可以避免不必要的更新和重复渲染,提高代码的性能和效率。

相关推荐
切糕师学AI5 分钟前
前后端分离架构中,Node.js的底层实现原理与线程池饥饿问题解析
前端·vue.js·node.js
妄小闲24 分钟前
网页设计模板 HTML源码网站模板下载
前端·html
icebreaker40 分钟前
tailwindcss 究竟比 unocss 快多少?
前端·css·github
卢叁1 小时前
Flutter之自定义TabIndicator
前端·flutter
每天吃饭的羊1 小时前
state和ref
前端·javascript·react.js
GEO_YScsn1 小时前
Vite:Next-Gen Frontend Tooling 的高效之道——从原理到实践的性能革命
前端·javascript·css·tensorflow
GISer_Jing1 小时前
滴滴二面(准备二)
前端·javascript·vue·reactjs
ningmengjing_1 小时前
webpack打包方式
前端·爬虫·webpack·node.js·逆向
Yuner20001 小时前
Webpack开发:从入门到精通
前端·webpack·node.js
GISer_Jing1 小时前
滴滴二面准备(一)
前端·javascript·面试·ecmascript