”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 反应新的更新

反应新的更新

发布于2024-07-31
浏览:550

React  The new updates

本周,我们将讨论新的 React 19 更新和挂钩。在经历并使用了其中一些新更新后,我只能同意它简化了开发人员在构建应用程序(尤其是与交互式表单相关的应用程序)时所经历的一些严格活动。

加入我,让我们探索其中的一些新更新。

React 编译器React 编译器选择您的 React 代码,将其转换为浏览器的 JavaScript 代码,并管理组件或用户界面的状态。这种单一的操作有助于优化应用程序的性能。

如果您熟悉 useMemo 钩子、useCallback 钩子和 React.Memo,您就会明白它们有助于记忆(存储值或函数以供将来使用)您的组件,因此它们不必重新编写当没有状态改变时渲染。当状态发生变化时,React 会重新渲染相关组件及其子组件,而当代码没有变化时,组件将保持原样,保留组件或钩子中的先前内存、值和状态以供将来使用用途;从而优化组件的性能。这正是 React 编译器自动执行的操作,无需手动调用任何上述钩子。

Form Actions:使用React的最大优势之一是状态的管理和突变,这主要发生在我们使用 元素。表单帮助我们更有效地创建和处理用户交互。

使用表单操作,您不需要像 onSubmit 和 onChange 这样的事件处理程序来实现数据的实时突变,相反,我们可以传递 action 属性到接收触发事件的函数的

元素。
const myFunction = async (formData) => {
  const [name, setName] = useState("")

  const updatedName = await nameChange(formData.get("name"))
     setName(updatedName)
}

通过这种方法,我们不需要应用useState通过event.target.value来改变数据,相反,在myFunction中我们可以通过参数获取变异数据。

这意味着我们必须从表单中的 元素设置一个 name 属性。使用此方法意味着我们允许 React 通过 Native React 表单对象 处理表单本身,而不是通过事件处理程序手动更改状态。

服务器组件:React 19 允许在捆绑之前在服务器上渲染组件,在与客户端应用程序或 SSR 服务器设置不同的环境中。 Server 组件与 SSR(服务器端渲染)不同,而是 React Server Components 中的一个独立的服务器环境。
此功能允许组件提前预渲染,从而实现快速内容显示并缩短加载时间。

元数据:React 19 允许灵活的元数据。开发者可以通过DocumentHead组件管理各个组件的titledescription以及其他meta标签。这将有助于改善 SEO(搜索引擎优化)。

Const AboutUs = () => {
 return (
    
      Learn more about our company
      
      // content
    >
  );
}

React 19 有一系列 钩子,一些是新的,另一些是对现有钩子的改进。下面我们就来讨论一下。

use() 钩子:use 钩子是一个实验性 API,可以直接用于读取组件或钩子中 Promise 或上下文的值(这是目前唯一已知的限制) )。
use hook 非常通用,也可以用来代替 useEffect,因为它可以用于异步数据获取。这有助于
实现更整洁、简洁的代码块。

警告它不是 useEffect 的替代品,因为它仍然有其自身的限制,_useEffect _将无限制地执行。

import {use} from "react"
const fetchData = async () => {
    const response = await fetch("https://........");
    return response.json()
}

const userData = () => {
    const user = use(fetchData());

        return (
    
{user.name}
); }

useActionState():这是一个新的钩子,有助于管理状态更改。它有助于管理挂起状态、错误处理和最终
状态更新。 useActionState _的工作方式与 _useReduce _in 类似,它接收两个 (2) 个参数:提交表单时要调用的函数和一个 _initialState,并且它返回一个包含三个 (3) 个值的数组: state,如果状态发生突变,则为当前状态,一个新的操作(formAction)可以作为表单组件中的道具传递以调用服务器操作,并且 _isPending _that 返回一个 _boolean _value 如果表格已提交。

import { useActionState } from "react";

async function incrementFunction(initialState, formData) {
  return initialState   1;
}

function StatefulForm({}) {
  const [state, formAction, isPending] = useActionState(incrementFunction, 0);

  console.log(state);

  return (
    
) }

在此示例中,每次单击按钮时,incrementFunction都会将1添加到stateinitialState 为 0,然后在第一次单击按钮时增加到 1,从而将 state 更改为 1,并且每次单击按钮都会为最后一次单击添加 1组件的状态。

useOptimistic() 钩子:

这是一个新的挂钩,允许用户甚至在页面完全加载之前就可以看到其操作的结果。即使服务器仍处于数据获取模式,页面也会乐观地呈现给用户。

React希望数据获取成功,向客户端显示预期的结果,当数据获取失败时,React恢复到之前状态的值以免显示错误的数据。这种独特的操作有助于无缝、快速地显示数据,从而改善用户体验。

useFormStatus():

顾名思义,useFormStatus为我们提供了表单表单字段的状态。这个钩子不接受任何参数,但它肯定返回 4 个对象:

待定:这将返回一个布尔值值:truefalse。提交表单时返回 true,提交表单时返回 false

data:当表单提交成功后,我们可以从表单字段中获取用户或对象的信息,如下所示:

(formData.get("name"))
(formData.get("address"))

method:除非另有说明,表单的默认方法是GET。我们可以使用 .method 获取表单的方法。当我们提交表单时,应将字符串方法属性指定为 POST

action:这是对将传递给 元素中的 action 属性的函数的引用。

useFormStatus 必须始终从 元素或在 内呈现的组件调用。

还有很多更新我无法真正写下来,所以你不会因为阅读这么多而感到无聊。您可以单击 React Docs 网站来查看其他一些更新。

我希望您和我一起学习愉快。

如果您喜欢我的文章,请关注我。

谢谢,祝朋友们度过愉快的一周。

版本声明 本文转载于:https://dev.to/oluwatrillions/react-19-the-new-updates-2k68?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    在默认值中使用current_timestamp或mysql版本中的current_timestamp或在5.6.5 这种限制源于遗产实现的关注,这些限制需要为Current_timestamp功能提供特定的实现。消息和相关问题 `Productid` int(10)unsigned not ...
    编程 发布于2025-02-06
  • 如何在JavaScript对象中动态设置键?
    如何在JavaScript对象中动态设置键?
    如何为JavaScript对象变量创建动态键,尝试为JavaScript对象创建动态键,使用此Syntax jsObj['key' i] = 'example' 1;将不起作用。正确的方法采用方括号:他们维持一个长度属性,该属性反映了数字属性(索引)和一个数字属性的数量。标准对象没有模仿这...
    编程 发布于2025-02-06
  • 我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    将我的加密库从mcrypt升级到openssl 问题:是否可以将我的加密库从McRypt升级到OpenSSL?如果是这样?使用openssl?答案:可以使用mcrypt数据加密数据,可以使用openssl。关于如何使用openssl对McRypt进行加密的数据: openssl_decrypt...
    编程 发布于2025-02-06
  • 如何使用Python的记录模块实现自定义处理?
    如何使用Python的记录模块实现自定义处理?
    使用Python的Loggging Module 确保正确处理和登录对于疑虑和维护的稳定性至关重要Python应用程序。尽管手动捕获和记录异常是一种可行的方法,但它可能乏味且容易出错。解决此问题,Python允许您覆盖默认的异常处理机制,并将其重定向为登录模块。这提供了一种方便而系统的方法来捕获和...
    编程 发布于2025-02-06
  • 如何使用char_length()在mySQL中按字符串长度对数据进行排序?
    如何使用char_length()在mySQL中按字符串长度对数据进行排序?
    [2使用内置的char_length()function。 char_length()和length() 此查询将从指定的表中检索所有行,并基于上升顺序对它们进行排序指定列的字符长度。带有更长字符串的行将出现在结果的底部。
    编程 发布于2025-02-06
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python 导入编解码器 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有表情符号 emoji_pattern = re.compile(“ [”...
    编程 发布于2025-02-06
  • 如何干净地删除匿名JavaScript事件处理程序?
    如何干净地删除匿名JavaScript事件处理程序?
    在这里工作/},false); 不幸的是,答案是否。除非在Creation中存储对处理程序的引用。要解决此问题,请考虑将事件处理程序存储在中心位置,例如页面的主要对象,请考虑将事件处理程序存储在中心位置,否则无法清理匿名事件处理程序。 。这允许在需要时轻松迭代和清洁处理程序。
    编程 发布于2025-02-06
  • 如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2025-02-06
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    克服go mod中的模块路径差异 coreos/bbolt:github.com/coreos/ [email受保护]:解析go.mod:模块将其路径声明为:go.etcd.io/bbolt `要解决此问题,您可以在go.mod文件中使用替换指令。只需在go.mod的末尾添加以下行:[&& &...
    编程 发布于2025-02-06
  • 如何使用组在MySQL中旋转数据?
    如何使用组在MySQL中旋转数据?
    在关系数据库中使用mysql组使用mysql组来调整查询结果。在这里,我们面对一个共同的挑战:使用组的组将数据从基于行的基于列的基于列的转换。通过子句以及条件汇总函数,例如总和或情况。让我们考虑以下查询: select d.data_timestamp, sum(data_id = 1 tata...
    编程 发布于2025-02-06
  • 如何在整个HTML文档中设计特定元素类型的第一个实例?
    如何在整个HTML文档中设计特定元素类型的第一个实例?
    [2单独使用CSS,整个HTML文档可能是一个挑战。 the:第一型伪级仅限于与其父元素中类型的第一个元素匹配。 以下CSS将使用添加的类样式的第一个段落: }
    编程 发布于2025-02-06
  • 为什么尽管有效代码,为什么在PHP中捕获输入?
    为什么尽管有效代码,为什么在PHP中捕获输入?
    [2 _post ['ss'];?> 的目的是从单击提交按钮时,文本框并显示。但是,输出保持空白。当方法=“ get”无缝工作时,方法=“ post”构成问题。 检查action属性:如果您正在刷新页面,请将操作属性设置为空字符串,例如] action ='&#...
    编程 发布于2025-02-06
  • 如何使用PHP从XML文件中有效地检索属性值?
    如何使用PHP从XML文件中有效地检索属性值?
    从php 您的目标可能是检索“ varnum”属性值,其中提取数据的传统方法可能会使您感到困惑。 - > attributes()为$ attributeName => $ attributeValue){ echo $ attributeName,'=“',$ at...
    编程 发布于2025-02-06
  • 如何从PHP服务器发送文件?
    如何从PHP服务器发送文件?
    将文件发送到user
    编程 发布于2025-02-06
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, AttributeError:SomeClass实...
    编程 发布于2025-02-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3