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..." 的占位符。

相关推荐
代码不加糖8 分钟前
2026 跨境电商独立站实战:从 0 到 1 搭建高转化 SaaS 商城(附源码)
开发语言·前端·javascript
亲亲小宝宝鸭27 分钟前
拖一拖控件,拖出个问卷(低代码平台)
前端·低代码
江南十四行28 分钟前
ReAct Agent 基本理论与项目实战(一)
前端·react.js·前端框架
We་ct1 小时前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划
小呆呆6661 小时前
Codex 穷鬼大救星
前端·人工智能·后端
当时只道寻常2 小时前
Vue3 + IntersectionObserver 实现高性能图片懒加载
前端
用户617517157012 小时前
关于普通函数和箭头函数的this
javascript
sakiko_2 小时前
UIKit学习笔记3-布局、滚动视图、隐藏或显示视图
前端·笔记·学习·objective-c·swift·uikit
RPGMZ3 小时前
RPGMakerMZ 地图存档点制作 标题继续游戏直接读取存档
开发语言·javascript·游戏·游戏引擎·rpgmz·rpgmakermz
有一个好名字3 小时前
Agent Loop —— 一切从那个 while 循环开始
前端·javascript·chrome