」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 反應新的更新

反應新的更新

發佈於2024-07-31
瀏覽:612

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]刪除
最新教學 更多>
  • PHP 的 `==` 和 `===` 運算子有什麼不同?
    PHP 的 `==` 和 `===` 運算子有什麼不同?
    PHP Double (==) 和 Triple (===) 相等比較有何不同? 在 PHP 中比較值時,兩個可以使用不同的運算子:鬆散相等 (==) 運算子和嚴格相同 (===) 運算子。了解它們的細微差別對於確保可靠的比較至關重要。 鬆散相等 (==) 比較鬆散相等運算子在比較值之前執行型別雜亂...
    程式設計 發佈於2024-12-21
  • 如何在 JavaScript 中對字串執行數學運算?
    如何在 JavaScript 中對字串執行數學運算?
    將字串轉換為數字進行數學運算儘管包含數字字符,但字串不能直接作為數字進行操作。要執行算術運算,必須先將它們轉換為數字形式。 考慮給出的例子:var num1 = '20', num2 = '30.5';直接添加這些字串會導致串聯:num1 num2; // '2030.5'要強制將它們視...
    程式設計 發佈於2024-12-21
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而非:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST陣列:表單提交後使用 var_dump 檢查 $_POST 陣列的內...
    程式設計 發佈於2024-12-21
  • 為什麼我的 Div 重疊?了解並解決保證金崩潰問題
    為什麼我的 Div 重疊?了解並解決保證金崩潰問題
    邊距折疊:理解並解決Div 佈局中的重疊設計具有多個div 元素的佈局時,理解邊距的概念至關重要折疊以避免不必要的重疊邊距。邊距折疊是一種 CSS 行為,當相鄰元素的邊距合併在一起時會發生,有效地增加了它們之間的總邊距空間。 邊距折疊的原因在您的具體情況,重疊邊距可能是由於以下CSS 規則的組合造成...
    程式設計 發佈於2024-12-21
  • 第一個 PHP 8.3 候選版本現已可測試
    第一個 PHP 8.3 候選版本現已可測試
    即將推出的 PHP 版本的第一個候選版本 PHP 8.3 現已可供測試。 第一個普遍可用的PHP 版本計劃於今年11 月23 日發布,PHP 8.3 的第一個候選版本是一個重要的預發布里程碑,因為它表明了PHP 8.3 的所有更改現在已經實現,只剩下完善和錯誤修復了。 在 11 月 23 日 ...
    程式設計 發佈於2024-12-21
  • 插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入記錄時如何解決「一般錯誤:2006 MySQL 伺服器已消失」介紹:將資料插入MySQL 資料庫有時會導致錯誤「一般錯誤:2006 MySQL 伺服器已消失」。當與伺服器的連線遺失時會出現此錯誤,通常是由於 MySQL 配置中的兩個變數之一所致。 解決方案:解決此錯誤的關鍵是調整wait_tim...
    程式設計 發佈於2024-12-21
  • 如何正確處理 JSON 資料中的換行符號?
    如何正確處理 JSON 資料中的換行符號?
    處理 JSON 中的換行符處理 JSON 資料時,必須正確處理換行符號以避免意外錯誤。以下是該問題及其解決方案的詳細說明。 問題使用eval 或JSON.parse 解析包含換行符的JSON 資料時,可能會遇到這樣的錯誤作為“未終止的字串文字” 。這是因為 JSON 中的雙引號字串中無法辨識換行符(...
    程式設計 發佈於2024-12-21
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-12-21
  • 您是否應該使用持久 PDO 連線:權衡效能效益與潛在風險?
    您是否應該使用持久 PDO 連線:權衡效能效益與潛在風險?
    使用持久PDO 連線的缺點:意外後果使用持久PDO 連線的缺點:意外後果雖然PDO 中的持久連線旨在透過快取和重複使用連線來增強效能,但它們可以還會引入可能影響效能的意外後果。 事務和連接狀態問題:持久連接的一個顯著缺點是意外的腳本終止會留下打開的連接,這可能會導致各種問題:鎖定表: 如果死腳本鎖定...
    程式設計 發佈於2024-12-21
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-12-21
  • 如何在 PHP 中顯示 MySQL BLOB 映像?
    如何在 PHP 中顯示 MySQL BLOB 映像?
    從MySQL 顯示PHP BLOB 影像背景在MySQL 資料庫中將影像作為二進位大物件(BLOB) 儲存和擷取是一種常見技術。然而,顯示這些圖像有時可能具有挑戰性。 解決方案解決方案插入映像:使用file_get_contents 函數讀取映像$query = "INSERT INTO ...
    程式設計 發佈於2024-12-21
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    程式設計 發佈於2024-12-21
  • 深入研究 Reactjs
    深入研究 Reactjs
    模因生成器 Meme Generator 是一個有趣的互動式 Web 應用程序,允許用戶使用各種模板創建自訂 Meme。我已經透過教育平台學習軟體開發幾個月了,這個專案是課程的一部分。 目錄 示範 特徵 技術堆疊 安裝 用法 作者 執照 表達您的支持 ...
    程式設計 發佈於2024-12-21
  • 如何使用 CSS 禁用連結?
    如何使用 CSS 禁用連結?
    CSS停用連結技巧問題:是否可以使用CSS停用連結?例如,如果您有一個名為“當前頁面”的類,您可能希望阻止該類的連結在單擊時處於活動狀態。 解決方案:以下 CSS 程式碼片段提供了一個簡單的解決方案:[aria-current="page"] { pointer-events...
    程式設計 發佈於2024-12-21
  • 如何讓我的 Python 類別 JSON 可序列化?
    如何讓我的 Python 類別 JSON 可序列化?
    使 Python 類別 JSON 可序列化序列化允許將物件轉換為適合持久或傳輸的格式。在 JSON 中序列化自訂類別通常會導致 TypeError,因為它們的非 JSON 可序列化性質。 實作 toJSON() 方法一種方法是建立一個類別的 toJSON() 方法,手動處理其序列化。這需要實作自訂 ...
    程式設計 發佈於2024-12-21

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3