はじめに
約 10 年前にソフトウェア開(kāi)発者としての道を歩み始めてからは、HTML、CSS、JavaScript、およびいくつかの Python 2 スクリプトをコーディングするだけでした。その間、私たちはサーバー側(cè)のクライアント/サーバー通信には PHP と SQL のみに依存していました。その次のレベルは、狀態(tài)や効果による変化に反応するといった魔法の言葉「React」です。これは、Facebook のエンジニアが作ったという噂によるもので、本件については深く掘り下げることなく、私の理解です。これは、フロントエンド部分のコーディングに使用していた方法では爆弾でした。
ソフトウェア開(kāi)発が進(jìn)化し、バックエンド システムが複雑になるにつれて、React Server Components (RSC) はエコシステムの進(jìn)化が切実に必要であると感じました。それは、大規(guī)模な JavaScript バンドルと「読み込み」スピナーがいたるところにあった時(shí)代を思い出させます。 RSC がどのようにゲームを変えているかを見(jiàn)てみましょう。
パフォーマンス革命
RSC がもたらす主な変化は技術(shù)的なものだけでなく、哲學(xué)的なものでもあります。 RSC を使用すると、コンポーネント ツリー全體をクライアントに送信するのではなく、React で気に入っている対話性を維持しながら、サーバー上でコンポーネントをレンダリングできます。以前はダッシュボード アプリケーションを RSC に移行していましたが、非常にシンプルで、この世のものとは思えません。ダッシュボード アプリケーションのサイズは 60% 減少しました。
これは私が最近遭遇した実際の例です:
// Before: Client Component import { ComplexDataGrid } from 'heavy-grid-library'; import { format } from 'date-fns'; export default function Dashboard() { const [data, setData] = useState([]); useEffect(() => { fetchDashboardData().then(setData); }, []); return <ComplexDataGrid data={data} />; }
この従來(lái)のクライアント側(cè)のアプローチでは、いくつかのことが起こります。
- クライアント JavaScript にバンドルされる重いデータ グリッド ライブラリをインポートしています。
- useState を使用して、ブラウザー內(nèi)でデータをローカルに管理しています。
- コンポーネントのマウント後に useEffect を使用してデータを取得しています。
- データがフェッチされている間、ユーザーには読み込み狀態(tài)が表示されます。
- すべてのデータ処理はブラウザ內(nèi)で行われるため、ユーザーのデバイスの速度が低下する可能性があります。
次に、RSC のバージョンを見(jiàn)てみましょう:
import { sql } from '@vercel/postgres'; import { DataGrid } from './DataGrid'; export default async function Dashboard() { const data = await sql`SELECT * FROM dashboard_metrics`; return <DataGrid data={data} />; }
- コンポーネントはデフォルトで非同期です。useEffect や useState は必要ありません。
- サーバー側(cè)クエリによる直接データベース アクセス。
- クライアント側(cè)のデータ取得コードは必要ありません。
- 初期データにはゼロロード狀態(tài)が必要です。
- データ処理はユーザーのデバイスではなく強(qiáng)力なサーバーで行われます。
- インポートされた DataGrid コンポーネントは、データの取得ではなく表示のみを処理する必要があるため、はるかに軽量になります。
その変化は驚くべきものです。 useEffect もクライアント側(cè)のデータ取得も不要になり、最も重要なことに、クライアントへの JavaScript の不必要な送信も不要になります。
現(xiàn)実世界の利點(diǎn)
その影響は単なるパフォーマンス指標(biāo)にとどまりません。 RSC を使用していると、データベース クエリがデータ ソースの近くで行われるようになり (上記の例では、コーディングのベスト プラクティスではありません)、コンポーネントがよりシンプルで焦點(diǎn)が絞られ、認(rèn)証と認(rèn)可のパターンがより単純になり、SEO が強(qiáng)化されていることに気づきました。改善はほぼ無(wú)料で行われますが、これは React の世界では以前には起こらなかったことです。
しかし、最も重要な利點(diǎn)は開(kāi)発者のエクスペリエンスです。データベースに直接アクセスできる (安全!) コンポーネントを作成することは、スーパーパワーのように感じられます。これは、React のコンポーネントベースのアーキテクチャと、Next.js
による最先端のサーバーサイド レンダリングによるパフォーマンスの利點(diǎn)の両方の長(zhǎng)所を併せ持つようなものです。トレードオフ
正直に言うと、RSC は完璧ではありません。メンタル モデルを把握するには、特にクライアントとサーバーの境界を理解するには時(shí)間がかかります。私にとっては、ブラックボックス內(nèi)での一種の複雑な操作です。前回の移行例に従いますが、RSC 互換ではないサードパーティのライブラリでいくつかの障害に遭遇しました。解決策は?ハイブリッド アプローチ:
// Before: Client Component import { ComplexDataGrid } from 'heavy-grid-library'; import { format } from 'date-fns'; export default function Dashboard() { const [data, setData] = useState([]); useEffect(() => { fetchDashboardData().then(setData); }, []); return <ComplexDataGrid data={data} />; }
このハイブリッド アプローチで何が起こっているのかを詳しく見(jiàn)てみましょう:
- use client ディレクティブは、SearchFilter をクライアント コンポーネントとして明示的にマークします。
- SearchFilter は、クライアントでのみ発生するユーザー インタラクション (onChange イベント) を処理します。
- ProductList はサーバー コンポーネントのままで、サーバー側(cè)でデータを取得します。
- コンポーネントの構(gòu)成により、必要に応じてサーバーとクライアントのレンダリングを混在させることができます。
- 対話型部分 (SearchFilter) のみが JavaScript をクライアントに伝えます。
- データ量の多い部分 (製品を含む ProductGrid) はサーバー上でレンダリングされます。
結(jié)論 (未來(lái)はサーバーファースト)
RSC は単なる新機(jī)能ではなく、React アプリケーションの構(gòu)築方法に伝わるパラダイムです。 React のコンポーネント モデルを維持しながら、高価な計(jì)算とデータのフェッチをサーバーに移動(dòng)できる機(jī)能は革新的です。
RSC は、データ量の多いアプリケーションを構(gòu)築しているチームに、開(kāi)発者のエクスペリエンスを犠牲にすることなくパフォーマンスを向上させる道を提供します。環(huán)境が成熟し、より多くのライブラリが RSC 互換になるにつれて、このパターンが React アプリケーションを構(gòu)築するデフォルトの方法になると予想しています。
あなたの経験を共有してください
プロジェクトで React Server コンポーネントの使用を開(kāi)始しましたか?以下のコメント欄で、挑戦や勝利についての意見(jiàn)をお待ちしています。
この記事が RSC についての理解を深めるのに役立った場(chǎng)合は、?? を付けてください。最新のシステムについてさらに詳しく知るために、私をフォローすることを忘れないでください。
著者について
Ivan Duarte は、フリーランスで働いた経験を持つバックエンド開(kāi)発者です。彼は Web 開(kāi)発と人工知能に情熱を持っており、チュートリアルや記事を通じて知識(shí)を共有することを楽しんでいます。さらに詳しい情報(bào)や最新情報(bào)を得るには、X、Github、LinkedIn で私をフォローしてください。
? ニュースレターを購(gòu)読する
ByteUp の記事を受信箱で直接読んでください。
ニュースレターを購(gòu)読して、お見(jiàn)逃しなく。
? 今すぐ購(gòu)読 ?
以上がReact サーバー コンポーネント: 進(jìn)化の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

ホットAIツール

Undress AI Tool
脫衣畫像を無(wú)料で

Undresser.AI Undress
リアルなヌード寫真を作成する AI 搭載アプリ

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

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無(wú)料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版
中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1
強(qiáng)力な PHP 統(tǒng)合開(kāi)発環(huán)境

ドリームウィーバー CS6
ビジュアル Web 開(kāi)発ツール

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

ホットトピック











JavaScriptisidealforwebdevelopment,whileJavasuitslarge-scaleapplicationsandAndroiddevelopment.1)JavaScriptexcelsincreatinginteractivewebexperiencesandfull-stackdevelopmentwithNode.js.2)Javaisrobustforenterprisesoftwareandbackendsystems,offeringstrong

JavaScriptでは、シングルラインコメント(//)またはマルチラインコメント(//)を選択することは、コメントの目的とプロジェクトの要件に依存します。 2。詳細(xì)なドキュメントには、マルチラインコメントを使用します。 3。コメントスタイルの一貫性を維持します。 4。過(guò)剰な承認(rèn)を避けます。 5.コメントがコードと同期して更新されていることを確認(rèn)してください。適切な注釈スタイルを選択すると、コードの読みやすさと保守性を向上させることができます。

はい、javascriptcommentsは不必要に使用されています。

JavaScriptcommentsEareEssentialential-formaining、およびGuidingCodeexecution.1)single-linecommentseared forquickexplanations.2)多LinecommentsexplaincomplexlogiCorprovidededocumentation.3)clarifyspartsofcode.bestpractic

JavaとJavaScriptは異なるプログラミング言語(yǔ)であり、それぞれ異なるアプリケーションシナリオに適しています。 Javaは大規(guī)模なエンタープライズおよびモバイルアプリケーション開(kāi)発に使用されますが、JavaScriptは主にWebページ開(kāi)発に使用されます。

ContureCrucialInjavascript formantaining andFosteringCollaboration.1)TheypindeBugging、Onboarding、およびUnderstandingCodeevolution.2)usesingle-linecomments for quickexplanations andmulti-linecomments fordeTeTaileddespransions.3)BestPractsinclud

javascripthasseveralprimitivedatypes:number、string、boolean、undefined、null、symbol、andbigint、andnon-primitiveTypeslike objectandarray

javascriptispreferredforwebdevelopment、whilejavaisbetterforlge-scalebackendsystemsandroidapps.1)javascriptexcelsininintingtivewebexperiences withitsdynAmicnature anddommanipulation.2)javaofferstruntypyping-dobject-reientedpeatures
