ホームページ ウェブフロントエンド jsチュートリアル React 安定版リリース: 新機能とアップグレード方法

React 安定版リリース: 新機能とアップグレード方法

Dec 06, 2024 pm 09:04 PM

React Stable Release: What’s New and How to Upgrade

React 19 は正式に安定しており、npm で利用できるようになりました。機能と拡張機能が満載されており、開発を合理化し、パフォーマンスを向上させ、一般的な UI パターンの処理を簡素化するように設計されています。ここでは、React 19 の新機能と、これらの機能をプロジェクトに導入する方法について包括的に説明します。

React 19 での主な追加

  1. アクションと非同期遷移

アクションにより、データの変更、保留状態、エラー処理、オプティミスティック更新などの非同期操作の管理が簡素化されます。 useTransition または新しい useActionState フックを使用すると、次のことが可能になります。

保留状態を自動的に処理します。

より適切なエラー処理を提供します。

action または formAction プロパティを使用して、

要素でフォームの送信を管理します。

例: useActionState を使用した簡略化されたフォーム

function ChangeName({ name, setName }) {
  const [error, submitAction, isPending] = useActionState(
    async (previousState, formData) => {
      const error = await updateName(formData.get("name"));
      if (error) {
        return error;
      }
      redirect("/path");
      return null;
    },
    null,
  );

  return (
    <form action={submitAction}>
      <input type="text" name="name" />
      <button type="submit" disabled={isPending}>Update</button>
      {error && <p>{error}</p>}
    </form>
  );
}
ログイン後にコピー
  1. useOptimistic を使用したオプティミスティック更新

新しい useOptimistic フックを使用すると、非同期応答を待機している間にユーザーに即時フィードバックを提供できます。

function ChangeName({ currentName, onUpdateName }) {
  const [optimisticName, setOptimisticName] = useOptimistic(currentName);

  const submitAction = async (formData) => {
    const newName = formData.get("name");
    setOptimisticName(newName);
    const updatedName = await updateName(newName);
    onUpdateName(updatedName);
  };

  return (
    <form action={submitAction}>
      <p>Your name is: {optimisticName}</p>
      <input type="text" name="name" />
    </form>
  );
}
ログイン後にコピー
  1. API を使用する

API を使用すると、Promise とコンテキストの条件付きレンダリングが可能になり、より柔軟なコンポーネント設計が可能になります。

import { use } from 'react';
function Comments({ commentsPromise }) {
  const comments = use(commentsPromise);
  return comments.map(comment => <p key={comment.id}>{comment}</p>);
}
ログイン後にコピー
  1. ネイティブメタデータ管理

React 19 は、コンポーネント内で

、 、およびタグを直接レンダリングし、それらをセクションに自動的にホイスティングすることをサポートしています。
function BlogPost({ post }) {
  return (
    <article>
      <title>{post.title}</title>
      <meta name="author" content="Author Name" />
    </article>
  );
}
ログイン後にコピー
  1. 強化されたスタイルシートとスクリプト管理

React 19 では、以下の組み込みサポートが導入されています。

.

を使用して優先順位が制御されたスタイルシート

コンポーネント ツリー内で非同期スクリプトがレンダリングされ、重複排除と正しい実行順序が保証されます。

<link rel="stylesheet" href="styles.css" precedence="default" />
<script async src="script.js"></script>
ログイン後にコピー
  1. サーバーのコンポーネントとアクション

React サーバー コンポーネントが安定し、事前にコンポーネントをレンダリングできるようになりました。サーバー アクション (「use server」ディレクティブによって有効化) と組み合わせると、クライアント コンポーネントは非同期サーバー側関数をシームレスに呼び出すことができます。

  1. エラー処理の改善

React 19 はエラー レポートを統合し、簡潔で実用的なエラー メッセージを提供します。開発者は、onCaughtError、onUncaughtError、および onRecoverableError を使用して詳細なエラー処理を行うことができるようになりました。

  1. プロップとして参照

関数コンポーネントは ref を prop として受け入れることができるようになり、forwardRef の必要性がなくなることでコードが簡素化されます。

  1. ハイドレーションとサードパーティの統合

React 19 は、ブラウザ拡張機能やサードパーティのスクリプトによって挿入された予期しない要素を適切に処理することにより、ハイドレーションを向上させます。

  1. リソースのプリロード

preload や preinit などのリソースのプリロード API を使用してパフォーマンスを最適化します:

import { preload, preinit } from 'react-dom';
preinit('script.js', { as: 'script' });
preload('font.woff', { as: 'font' });
ログイン後にコピー

アップグレード方法

詳しい手順については、React 19 アップグレード ガイド (https://react.dev/blog/2024/12/05/react-19) に従ってください。主な考慮事項は次のとおりです:

重大な変更 (ガイドに記載)。

アプリの互換性をテストします。

React をピア依存関係として使用する依存関係を更新します。

今すぐ始めましょう

npm 経由でプロジェクトを React 19 にアップグレードします:

npm install 反応@19 反応-dom@19

これらの新機能とベスト プラクティスについてのより深い洞察については、React 19 の公式ドキュメント (https://react.dev/blog/2024/12/05/react-19) を参照してください。

React 19 は飛躍的な進歩を表し、動的でパフォーマンスが高く、アクセスしやすいアプリケーションを作成するための強力なツールを開発者に提供します。今日から探検を始めましょう!

以上がReact 安定版リリース: 新機能とアップグレード方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JavaScriptエンジン:実装の比較 JavaScriptエンジン:実装の比較 Apr 13, 2025 am 12:05 AM

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

Python vs. JavaScript:学習曲線と使いやすさ Python vs. JavaScript:学習曲線と使いやすさ Apr 16, 2025 am 12:12 AM

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

JavaScript:Web言語の汎用性の調査 JavaScript:Web言語の汎用性の調査 Apr 11, 2025 am 12:01 AM

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合) next.jsを使用してマルチテナントSaaSアプリケーションを構築する方法(フロントエンド統合) Apr 11, 2025 am 08:22 AM

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合) next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合) Apr 11, 2025 am 08:23 AM

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

C/CからJavaScriptへ:すべてがどのように機能するか C/CからJavaScriptへ:すべてがどのように機能するか Apr 14, 2025 am 12:05 AM

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

JavaScriptとWeb:コア機能とユースケース JavaScriptとWeb:コア機能とユースケース Apr 18, 2025 am 12:19 AM

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。

JavaScript in Action:実際の例とプロジェクト JavaScript in Action:実際の例とプロジェクト Apr 19, 2025 am 12:13 AM

現実世界でのJavaScriptのアプリケーションには、フロントエンドとバックエンドの開発が含まれます。 1)DOM操作とイベント処理を含むTODOリストアプリケーションを構築して、フロントエンドアプリケーションを表示します。 2)node.jsを介してRestfulapiを構築し、バックエンドアプリケーションをデモンストレーションします。

See all articles