
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 (
dashboard
);
}
function app() {
return (
}>
} />
} />
);
}
父路由路径=“/”表示占位符或您想要加载动态组件的页面布局,上面示例中的 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 (
{book.title}
{book.description}
}>
Could not load reviews ?
}
children={(resolvedReviews) => (
)}
/>










