React.lazy 和 suspense 如何使用?

React.lazy 和 suspense 如何使用?

React.lazy 可以让你延迟加载组件,只有在组件需要渲染时才会加载,这样可以提高应用的性能。它的用法是这样的:

javascript 复制代码
import lazy from'react';

const LazyComponent = lazy(() => import('./MyComponent'));

function MyApp() {
  return (
  <div>
  <LazyComponent />
  </div>
  );
}

export default MyApp;

而 Suspense 则是用于处理异步操作的,比如数据加载。它可以让你的应用在数据加载时显示一个占位符,等数据加载完成后再显示实际的内容。使用 Suspense 需要搭配useEffect和Promise来实现,比如:

javascript 复制代码
import { Suspense } from'react';

function DataComponent() {
  const [data, setData] = useState(null);

  useEffect(() => {
  const fetchData = async () => {
  const response = await fetch('https://example.com/data');
  const data = await response.json();
  setData(data);
  };
  fetchData();
  }, []);

  if (!data) {
  throw new Promise.reject();
  }

  return <div>{data}</div>;
}

function App() {
  return (
  <div>
  <Suspense fallback={<div>Loading...</div>}>
  <DataComponent />
  </Suspense>
  </div>
  );
}

export default App;

在这个例子中,DataComponent会在数据加载完成后显示数据,如果数据还没加载完成,就会显示一个 "Loading..." 的占位符。

相关推荐
技术钱7 分钟前
react antdesign实现表格嵌套表单
前端·react.js·前端框架
小p18 分钟前
react学习4:CSS Modules 样式
前端·react.js
东华帝君20 分钟前
小型列表是否需要拆分成服务器组件
前端
卍郝凝卍21 分钟前
物联网卡摄像头从前端至后台的实现过程
前端·物联网·视频解决方案
疯狂暴龙GG帝22 分钟前
项目中使用el-table实现行合并及合并后序号不连续解决方案
前端·vue.js
东华帝君24 分钟前
React Hook Form —— useForm 和 FormProvider+useFormContext
前端
小p34 分钟前
react学习3: 闭包陷阱
前端·react.js
朴shu41 分钟前
Delta数据结构:深入剖析高效数据同步的奥秘
javascript·算法·架构
该用户已不存在44 分钟前
Vibe Coding 入门指南:从想法到产品的完整路径
前端·人工智能·后端
Pedro1 小时前
Flutter - 日志不再裸奔:pd_log 让打印有型、写盘有序
前端·flutter