当前位置:首页 > 文章列表 > 文章 > 前端 > 反应新的更新

反应新的更新

来源:dev.to 2024-07-29 12:24:45 0浏览 收藏

一分耕耘,一分收获!既然打开了这篇文章《反应新的更新》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!

反应新的更新

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

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

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

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

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

使用 form actions,您不需要像 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 有一系列new 钩子,一些是新的,另一些是对现有钩子的改进。下面我们就来讨论一下吧。

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) 个值的数组:状态,即现在,如果状态发生突变,则为当前状态,一个新的操作(formaction)可以作为表单组件中的道具传递以调用服务器操作,如果表单已提交,则_ispending_将返回_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添加到状态initialstate 为 0,然后在第一次单击按钮时增加到 1,从而将 state 更改为 1,并且每次单击按钮都会为组件的最后一个状态添加 1。

useoptimistic() 钩子:

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

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

useformstatus():

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

pending:这会返回一个boolean值:truefalse。当表单提交时返回true,当表单提交时返回false

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

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

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

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

必须始终从

元素或在 . 内呈现的组件调用 useformstatus

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

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

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

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

理论要掌握,实操不能落!以上关于《反应新的更新》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
golang 框架的 HTTP 路由最佳实践golang 框架的 HTTP 路由最佳实践
上一篇
golang 框架的 HTTP 路由最佳实践
golang的框架如何处理部分成功的错误?
下一篇
golang的框架如何处理部分成功的错误?
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    28次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    42次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    39次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    51次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    42次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码