新的 React 带来了什么 - 获得清晰的了解
React 19 于 2024 年 4 月 25 日发布。JavaScript 世界变化如此之快,有时让人感觉难以跟上。但是,当这些更改旨在让您作为 React 开发人员的生活变得更轻松时,就值得一看,对吧?由于 React 是这个生态系统中如此重要的一部分,因此保持更新是必须的。
React 19 最好的部分是它专注于让事情变得更简单。这些更新旨在让学习 React 变得更容易,让您花更多时间进行创建,而不是处理棘手的设置。一些新功能确实改变了游戏规则,可能会极大地改变您的工作方式,所以您绝对不想错过它们。
我总是尝试以易于理解的方式解释事物,而不使用复杂的词语。本文也不例外。我的目标是确保您清楚了解所有内容,所以让我们一起探索 React 19 中的精彩更新!
请记住,React 19 还不太稳定。目前它被称为 React Canary。因此,请记住,实际上并不建议将其用于生产。
反应编译器
为了优化我们的 React 应用程序,我们使用一些内置方法,例如 useMemo、useCallback 或 memo。这告诉 React 如果输入没有改变就不要再次编译代码。但如果你忘记应用记忆化,就会导致浪费 React 资源和计算能力。为了解决这个问题,React 19 引入了 React Compiler。 React 的新编译器是 19 版本新发布的亮点。新的编译器会在幕后优化您的代码,因此您可以放弃这些钩子并专注于编写漂亮、干净的 React 组件。
简而言之,您不需要使用 useMemo 或 useCallback 包装函数来优化性能,也不需要使用 memo 包装组件来防止重新渲染组件。
操作(useTransition 挂钩)
我们来聊点废话吧?!!你是否注意到在 React 19 发布之前 useTransition 钩子几乎没有被提及?还是只有我这样?嗯,至少这是我注意到的,尤其是对于初级开发人员来说。无论如何,让我向您介绍一下它在之前版本中的工作原理,然后我们将了解为什么它现在如此重要。
useTransition 返回一个包含两个元素的数组:startTransition 函数和 isPending 布尔值。您可以将状态更新包装在 startTransition 函数中,以将它们标记为转换(优先级较低的代码)。这意味着用 startTransition 包裹的部分在其他连续任务完成后开始工作。
在 React 18 中,startTransition 函数不直接支持异步函数。这是一个限制,因为 startTransition 旨在将更新标记为低优先级,但无法原生处理异步逻辑。
在 React 19 中,此限制已得到解决。现在,startTransition 支持异步函数,这意味着您可以在其中执行异步任务(例如,数据获取),同时将这些更新标记为转换。此增强功能允许更灵活和直观地使用 startTransition,使其感觉像是一项“新”功能,尽管它在技术上是对现有功能的改进。
?
按照惯例,使用异步转换的函数称为“操作”。
例如,您可以在 useState 中处理挂起和错误状态:
// Before Actions function UpdateName({}) { const [name, setName] = useState(""); const [error, setError] = useState(null); const [isPending, setIsPending] = useState(false); const handleSubmit = async () => { setIsPending(true); const error = await updateName(name); setIsPending(false); if (error) { setError(error); return; } redirect("/path"); }; return ( <div> <input value={name} onChange={(event) => setName(event.target.value)} /> <button onClick={handleSubmit} disabled={isPending}> Update </button> {error && <p>{error}</p>} </div> ); }
React 19 支持在转换中使用异步函数来自动处理待处理状态、错误、表单和乐观更新。例如,您可以使用 useTransition 来为您处理挂起状态:
// Using pending state from Actions function UpdateName({}) { const [name, setName] = useState(""); const [error, setError] = useState(null); const [isPending, startTransition] = useTransition(); const handleSubmit = () => { startTransition(async () => { const error = await updateName(name); if (error) { setError(error); return; } redirect("/path"); }) }; return ( <div> <input value={name} onChange={(event) => setName(event.target.value)} /> <button onClick={handleSubmit} disabled={isPending}> Update </button> {error && <p>{error}</p>} </div> ); }
异步转换将立即将 isPending 状态设置为 true,发出异步请求,并在任何转换后将 isPending 切换为 false。这使您可以在数据更改时保持当前 UI 的响应能力和交互性。
<表格>行动
React 团队添加了对传递函数作为操作的支持。
export default function App() { const [name, setName] = useState( () => JSON.parse(localStorage.getItem("name")) || "Anonymous user" ) async function formAction(formData){ try { const newName = await updateNameInDB(formData.get("name")) setName(newName) } } return ( <> <p className="username"> Current user: <span>{name}</span> </p> <form action={formAction}> <input type="text" name="name" required /> <button type="submit">Update</button> </form> </> ) }
formAction 函数(您可以命名任何名称)在其参数中获取表单数据。每个字段都由名称属性表示,因此在命名输入时必须小心。 formData 参数实际上是本机 FormData Web API 对象。您可以在 mdn 网络文档上找到它。另一个好处是你不需要应用 event.preventDefault(),因为它是由 React 处理的。
当表单操作成功时,React 会自动重置表单。但如果你想重置
以上是新的 React 带来了什么 - 获得清晰的了解的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

学习JavaScript不难,但有挑战。1)理解基础概念如变量、数据类型、函数等。2)掌握异步编程,通过事件循环实现。3)使用DOM操作和Promise处理异步请求。4)避免常见错误,使用调试技巧。5)优化性能,遵循最佳实践。

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

zustand异步操作中的数据更新问题在使用zustand状态管理库时,经常会遇到异步操作导致数据更新不及时的问题。�...
