首页 > 其他分享 >如何使用 useTransition hook 提高 React 性能

如何使用 useTransition hook 提高 React 性能

时间:2024-09-22 09:48:03浏览次数:7  
标签:react gt const useTransition React hook result 钩子 post

react 是一个用于构建用户界面的流行 javascript 库。它以高效且专注于创建可重用的 ui 组件而闻名。 react 的关键特性之一是引入了钩子,它是挂钩到 react 状态的函数。这些钩子中的一个是 usetransition 钩子。该钩子允许在不阻塞界面的情况下进行状态更改,从而带来流畅的体验。 了解 usetransition 钩子为了更好地理解 usetransition 钩子,我们将研究以下示例。import {usestate} from "react"const app = () =&gt; { const [post, setpost] = usestate(undefined) const fetchdata = async () =&gt; { await fetch("https://jsonplaceholder.org/posts/1") .then((result) =&gt; result.json()) .then((result) =&gt; setpost(result)) } return( <div> {post !== undefined &amp;&amp; ( <div classname="post-card"> <h2>{post?.title}</h2> <image src="%7Bpost?.image%7D"></image><p>{post?.content}</p> </div> )} <button onclick="{fetchdata}"> get post </button> </div> )}export default app; 登录后复制当用户单击按钮时,根据互联网的速度或 fetchdata 函数内执行的任务的繁重,ui 可能会在获取任务期间冻结,这将导致用户体验不佳。如果您不希望用户滥用您的应用程序,也可能会向按钮发送垃圾邮件。此外,应用程序不会向用户显示任何正在进行的操作的指示。使用 usetransition 钩子可以轻松解决这些问题,我们可以将之前的代码更新为类似这样的内容。import {useState, useTransition} from "react"import {ImSpinner2} from "react-icons/im"const App = () =&gt; { const [pending, startTransition] = useTransition() const [post, setPost] = useState({}) const fetchData = () =&gt; { startTransition( async () =&gt; { await fetch("https://jsonplaceholder.org/posts/1") .then((result) =&gt; result.json()) .then((result) =&gt; setPost(result)) }) } return( <div> {post !== undefined &amp;&amp; ( <div classname="post-card"> <h2>{post.title}</h2> <image src="%7Bpost.image%7D"></image><p>{post.content}</p> </div> )} <button disabled onclick="{fetchData}"> {pending ? <imspinner2 classname="animate-spin"></imspinner2> : "Get post" } </button> </div> )}export default App; 登录后复制调用的usetransition钩子返回两个值:pending,如果任务执行完毕并且starttransition函数包含可能被更紧急的任务打断的任务,则该值将为true。在上面的示例中,我们将获取请求包装在 starttransition 函数内的异步箭头函数中。并且在按钮中,我们以包含链接到待处理的禁用属性的方式对其进行修改,并且我们更改了按钮的标签,以在任务待处理时显示微调器,并在任务待处理时显示标签“获取帖子”任务没有待处理。这会带来流畅的用户体验,并提供更好的性能,并保护您的应用程序免受用户不当行为的影响。 结论usetransition 钩子是一个游戏规则改变者,用于构建具有流畅用户体验的高性能 react 应用程序。它确保 ui 在可能缓慢的操作期间保持响应并防止 ui 冻结,从而增强整体用户体验。 以上就是如何使用 useTransition hook 提高 React 性能的详细内容,更多请关注我的其它相关文章!

标签:react,gt,const,useTransition,React,hook,result,钩子,post
From: https://www.cnblogs.com/aow054/p/18424936

相关文章

  • 如何在 React 中使用上下文
    欢迎回来,朋友们!?今天我们将回顾名为usecontext的reacthook的基础知识。usecontext是一个强大的工具,它比usestate更进一步,创建了一个类似全局的state,可以将信息传递给子组件和孙组件,而无需直接传递props。?但我有点超前了。?如果你不熟悉usestate,请先跳过去阅读我之前......
  • 如何在 ReactJS 中创建可重用的 Button 组件
    按钮无疑是任何react应用程序中重要的ui组件,按钮可能用于提交表单或打开新页面等场景。您可以在react.js中构建可重用的按钮组件,您可以在应用程序的不同部分中使用它们。因此,维护您的应用程序将变得更加简单,并且您的代码将保持dry(不要重复)。您必须首先在组件文件夹中创建一......
  • 如何使您的 React 应用程序更快:性能提示和最佳实践
    啊,反应!我们喜爱的用于构建ui的库。它就像一剂神奇的药剂,让我们的网络应用程序感觉具有交互性和快速性——直到有一天,它却没有了。突然,你注意到事情变慢了。点击按钮就像用信鸽寄信一样。您的应用程序从快如闪电变成了慢吞吞,用户开始给您“看”。不过别担心!就像咖啡可以解决大部......
  • 如何使用 AWS 部署带有自定义域的 React 项目?
    使用aws(amazonwebservices)等云提供商通过自定义域部署react应用程序可能看起来令人畏惧,但当分解为可管理的步骤时,它就很简单。在本文中,我们将指导您完成从构建应用程序到使其在您的自定义域上运行的整个过程。当您准备好与世界分享您的react项目时,使用自定义域部署它可以为......
  • 如何使用 React Router DOM
    介绍欢迎来到我们关于reactrouterdom的深入教程!如果您是一名ui开发人员,希望通过动态路由功能增强react应用程序,那么您来对地方了。reactrouterdom是一个功能强大的库,允许您创建具有多个视图的单页面应用程序,同时保持流畅、无缝的用户体验。在这份综合指南中,我们将引导......
  • 在画中画窗口中安装 React 组件
    google在chrome116中引入了documentpictureinpictureapi。在本文中,我们将探讨如何在画中画窗口中安装一个简单的react组件,而无需先将其安装在我们的主应用程序上。第1步-设置组件结构我们制造两个组件。maincomponent.js和counter.js。在maincomponent.js中,我们......
  • 在网站中实现 React tsarticles
    react-tsarticles是一个功能强大的库,可让您向react应用程序添加可自定义的粒子动画。在本指南中,我们将逐步介绍在您的项目中实现react-tsparticles的过程。安装首先,您需要安装必要的软件包。打开终端并运行以下命令:npminstalltsparticles@tsparticles/react登录后复制这将......
  • 增强 React 列表渲染:干净且可重用的模式
    作为react开发人员,我们都遇到过需要渲染数据列表的场景。虽然.map()方法效果很好,但每次渲染列表时重复相同的逻辑可能会让人筋疲力尽,并导致代码重复。幸运的是,有一种更干净、可扩展的方法来处理这个问题,使用可重用组件、高阶组件或自定义挂钩。在本文中,我将分享一种改进react......
  • 在 React 中创建自定义 Hook 的最佳技巧
    react的自定义hooks是从组件中删除可重用功能的有效工具。它们支持代码中的dry(不要重复)、可维护性和整洁性。但开发有用的自定义钩子需要牢牢掌握react的基本思想和推荐程序。在这篇文章中,我们将讨论在react中开发自定义钩子的一些最佳策略,并举例说明如何有效地应用它们。......
  • 在 React 中管理同一组件的多个实例中的状态
    当您使用react并拥有同一组件的多个实例时,管理状态可能会变得很棘手。根据组件需要交互的方式,您需要以不同的方式处理状态。这是我发现效果很好的方法。独立实例:将状态保留在组件内部如果您的组件不需要相互通信,最好将它们的状态保留在组件内。这样,每个实例都有自己的状态......