首页  >  文章  >  web前端  >  React 要点:您可能缺少的功能

React 要点:您可能缺少的功能

PHPz
PHPz原创
2024-08-19 17:14:17380浏览

React Essentials: Features You Might Be Missing

React 巩固了其作为构建动态和响应式用户界面的首选库的地位。凭借其声明式方法和基于组件的架构,React 简化了开发现代应用程序的复杂过程。然而,与任何强大的工具一样,即使对于经验丰富的开发人员来说,也有一些功能和最佳实践经常被忽视。

在本博客中,我们将深入研究 React 的一些被忽视的方面,这些功能可以增强您的开发工作流程、优化性能并帮助您编写更清晰、更高效的代码。

1.布局钩子(useLayoutEffect)

每个人都听说过 useEffect 钩子,它可以让您在依赖项发生变化时编写有效的代码。 useLayoutEffect 是 useEffect 钩子的一个版本,每当浏览器重新绘制屏幕时就会触发它,它在许多场景中都很有用。

工具提示

import { useState, useRef, useLayoutEffect } from 'react';

function Tooltip() {
  const ref = useRef(null);
  const [tooltipHeight, setTooltipHeight] = useState(0);

useLayoutEffect(() => {
    const { height } = ref.current.getBoundingClientRect();
    setTooltipHeight(height);
}, []);
// ...

这里的代码在屏幕渲染之前检查工具提示是否能够适合屏幕,因此会自行重新排列。

详细解释请访问 https://react.dev/reference/react/useLayoutEffect

2. 出口(React Router)

虽然不是 React 原生的一部分,但在 React 中管理路由时,React Router 是一个非常著名且有用的库。随着它的流行,它的文档中提到的许多功能都被忽视了。

插座的使用方法

曾经为您的项目设计过仪表板吗?顶部栏和侧边栏元素始终保持不变,并且只有页面的一部分在不同路线之间发生变化?这正是嵌套路由和出口概念发挥作用的地方

function Dashboard() {
  return (
    <div>
      <h1>Dashboard</h1>
      <Outlet />
    </div>
  );
}

function App() {
  return (
    <Routes>
      <Route path="/" element={<Dashboard />}>
        <Route path="messages" element={<DashboardMessages />} />
        <Route path="tasks" element={<DashboardTasks />} />
      </Route>
    </Routes>
  );
}

父路由path="/"表示占位符或您想要加载动态组件的页面布局,上例中的Dashboard()将只有一个标题,页面上的以下内容将取决于在我们位于 /messages 或 /tasks 的路线上。我们还可以使用outletContext

为所有子页面创建上下文

了解更多信息:https://reactrouter.com/en/main/components/outlet

3.加载优化(React.Suspense + Await)

React 在 React Router 的帮助下支持加载器和后备,无需使用任何其他库,这里是一个如何使用它们的简单示例。

function Book() {
  const { book, reviews } = useLoaderData();
  return (
    <div>
      <h1>{book.title}</h1>
      <p>{book.description}</p>
      <React.Suspense fallback={<ReviewsSkeleton />}>
        <Await
          resolve={reviews}
          errorElement={
            <div>Could not load reviews ?</div>
          }
          children={(resolvedReviews) => (
            <Reviews items={resolvedReviews} />
          )}
        />
      </React.Suspense>
    </div>
  );
}

注意:Await 期望在 内部渲染。或 父级启用后备 UI。

概括

我们探索了一些经常被忽视但强大的 React 功能,这些功能可以显着增强您的开发过程。我们从嵌套路由和 Outlet 组件的使用开始,这简化了应用程序中子路由的处理。接下来,我们深入研究了布局挂钩,特别是 useLayoutEffect,它对于在浏览器重绘之前执行更新至关重要,确保 UI 交互更加流畅。我们还讨论了 React 的 Await 和 Suspense 标签的使用,它们有助于更有效地管理异步操作,使您能够构建更快、响应更灵敏的用户界面。通过理解和利用这些功能,您可以编写更干净、更高效的 React 代码,并针对性能和可扩展性进行了优化。

以上是React 要点:您可能缺少的功能的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn