react18中在列表中如何使用useCallback进行渲染优化

实现的需求:在列表中如何缓存每个子组件,父组件重新渲染,子组件不更新,下面的列子假设 Chart 组件被包裹在memo 中。你希望在 ReportList 组件重新渲染时跳过重新渲染列表中的每个 Chart。但是,你不能在循环中调用 useCallback

实现效果

  • 代码逻辑

ReportList.js

js 复制代码
import { useCallback, useState } from "react";
import Chart from "./Chart";
function sendReport(item) {
  console.log("Sending report for", item);
}

function ReportList({ items }) {
  const [msg, setMsg] = useState("hello");
  function handleChange(e) {
    setMsg(e.target.value);
    console.log(msg);
  }
  return (
    <article>
      {items.map((item) => {
        // 🔴 你不能在循环中调用 useCallback:
        // const handleClick = useCallback(() => {
        //  sendReport(item)
        //}, [item]);

        //return (
        //  <figure key={item.id}>
        //    <Chart onClick={handleClick} />
        //  </figure>
        //);
        return <Report key={item.id} item={item} />;
      })}
      <input type="text" value={msg} onChange={handleChange} />
    </article>
  );
}

function Report({ item, onClick }) {
  const handleClick = useCallback(() => {
    sendReport(item);
  }, [item]);

  return (
    <figure key={item.id}>
      <Chart onClick={handleClick} />
    </figure>
  );
}

export default ReportList;

注意:我们不能在迭代中使用useCallback

Chart.js

js 复制代码
function Chart({ onClick }) {
  console.log("chart");
  return <button onClick={onClick}>Send Report</button>;
}
export default Chart;

发现chart组件还是会重新渲染,这个不是我们想要的效果。对代码进行改写

js 复制代码
import { memo } from "react";

const Chart = memo(function ({ onClick }) {
  console.log("chart");
  return <button onClick={onClick}>Send Report</button>;
});
export default Chart;

这样,我们就实现了效果。

相关推荐
加洛斯1 分钟前
箭头函数的艺术:如何优雅的写好JS代码
前端·javascript
克喵的水银蛇2 分钟前
Flutter 自定义 Widget 实战:封装通用按钮 + 下拉刷新列表
前端·javascript·flutter
Li_na_na012 分钟前
React+dhtmlx实现甘特图
前端·react.js·甘特图
用户2965412759173 分钟前
JSAPIThree 加载 Cesium 数据学习笔记:使用 Cesium 地形和影像服务
前端
csdn小瓯5 分钟前
一个现代化的博客应用【react+ts】
前端·react.js·前端框架
一颗不甘坠落的流星8 分钟前
【@ebay/nice-modal-react】管理React弹窗(Modal)状态
前端·javascript·react.js
黛色正浓8 分钟前
【React】极客园案例实践-Layout模块
前端·react.js·前端框架
辛-夷10 分钟前
vue高频面试题
前端·vue.js
IT小哥哥呀13 分钟前
《纯前端实现 Excel 导入导出:基于 SheetJS 的完整实战》
前端·excel
郑州光合科技余经理15 分钟前
技术架构:跑腿配送系统海外版源码全解析
java·开发语言·前端·数据库·架构·uni-app·php