目次
最後に
ホームページ ウェブフロントエンド jsチュートリアル [翻訳] カスタムフックを使用した React コンポーネントのリファクタリング

[翻訳] カスタムフックを使用した React コンポーネントのリファクタリング

Jan 17, 2023 pm 08:13 PM
javascript フロントエンド react.js

[翻訳] カスタムフックを使用した React コンポーネントのリファクタリング

React 関数コンポーネントについてよく話され、関数コンポーネントは必然的に大きくなり、より複雑なロジックになるという話を聞きます。結局のところ、コンポーネントを「関数」で記述したため、コンポーネントが拡張され、関数も拡張し続けることを受け入れる必要があります。これは React コンポーネントでも説明されています。

関数コンポーネントでできることはますます増えているため、コード ベース内の関数コンポーネントは全体的にどんどん長くなります。 [関連する推奨事項: Redis ビデオ チュートリアル プログラミング ビデオ ]

また、次のことを行う必要があるとも述べられています。抽象化を時期尚早に追加することを避ける

CodeScene を使用している場合、関数が長すぎるか複雑すぎる場合に警告が表示されることに気づくかもしれません。前述の内容に従う場合は、CodeScene 関連の警告をより広範囲に設定する必要があるかどうかを検討する可能性があります。もちろんこれを行うこともできますが、私はこれをすべきではないと思いますし、コードに多くの抽象化を追加することを拒否すべきではありません。それによって多くのメリットが得られますが、ほとんどの場合、コストはかかりません。高い。コードの健全性を引き続き非常に良好に保つことができます。

複雑さへの対処

関数コンポーネントは「関数」で記述されていますが、この関数は他の関数と同様であり、次のもので構成できることを認識する必要があります。その他多くの機能。 useState

useEffect、またはその他のフックと同様、サブコンポーネント自体も関数です。したがって、同じ考え方を自然に使用して、関数コンポーネントの複雑さに対処できます。 新しい関数を作成することで、公開パターンに準拠した複雑なコードをカプセル化できます複雑なコンポーネントを処理するより一般的な方法は、コンポーネントを複数のサブコンポーネントに分解することです。ただし、そうすると不自然に感じられたり、これらのサブコンポーネントを正確に説明することが難しくなる場合があります。このとき、コンポーネントのフック関数のロジックを整理することで、新たな抽象点を発見することができます。

コンポーネント内に

useState

useEffect、またはその他の組み込みフック関数の長いリストが表示されるたびに、それらをカスタム ファイルに抽出できるかどうかを検討する必要があります。針。カスタムフック関数は、その中で他のフック関数を利用できる関数であり、カスタムフック関数の作成も簡単です。 以下に示すコンポーネントはダッシュボードに相当し、リストを使用してユーザー ウェアハウス (github に似たものを想像してください) のデータを表示します。このコンポーネントは複雑なコンポーネントではありませんが、カスタム フックを適用する方法の良い例です。

function Dashboard() {
  const [repos, setRepos] = useState<Repo[]>([]);
  const [isLoadingRepos, setIsLoadingRepos] = useState(true);
  const [repoError, setRepoError] = useState<string | null>(null);

  useEffect(() => {
    fetchRepos()
      .then((p) => setRepos(p))
      .catch((err) => setRepoError(err))
      .finally(() => setIsLoadingRepos(false));
  }, []);

  return (
    <div className="flex gap-2 mb-8">
      {isLoadingRepos && <Spinner />}
      {repoError && <span>{repoError}</span>}
      {repos.map((r) => (
        <RepoCard key={i.name} item={r} />
      ))}
    </div>
  );
}
ログイン後にコピー

フック ロジックをカスタム フックに抽出します。このコードを

use

で始まる関数にコピーするだけです (ここでは

useRepos# と名前を付けます) ##): <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>/** * 请求所有仓库用户列表的hook函数 */ export function useRepos() { const [repos, setRepos] = useState&lt;Repo[]&gt;([]); const [isLoading, setIsLoading] = useState(true); const [error, setError] = useState&lt;string | null&gt;(null); useEffect(() =&gt; { fetchRepos() .then((p) =&gt; setRepos(p)) .catch((err) =&gt; setError(err)) .finally(() =&gt; setIsLoading(false)); }, []); return [repos, isLoading, error] as const; }</pre><div class="contentsignin">ログイン後にコピー</div></div>use で始まる必要がある理由は、

linter

プラグインが現在作成しているものがフック関数であることを検出できるためです。これにより、プラグインはフック関数がカスタム フックの正しい 関連ルール に準拠しているかどうかをチェックできます。 リファイン前と比較して、リファイン後に新たに現れたのは、return ステートメント

as const

だけです。ここでの型ヒントは、型推論が正しいことを確認するためのものです: 3 つの要素を含む配列、型は Repo[]、boolean、string | null です。もちろん、フック関数から望むものを返すことができます。 翻訳者注: ここに as const

を追加してください。ts 型推論の違いは、主に数値要素の数に反映されます。
as const

を追加しない場合、推論される型は (string | boolean | Repo[] | null)[] です。追加後の推論される型は readonly [Repo[] 、ブール値、文字列 | null]カスタム フック useRepos

をコンポーネントに適用すると、コードは次のようになります。
function Dashboard() {
  const [repos, isLoadingRepos, repoError] = useRepos();

  return (
    <div className="flex gap-2 mb-8">
      {isLoadingRepos && <Spinner />}
      {repoError && <span>{repoError}</span>}
      {repos.map((i) => (
        <RepoCard key={i.name} item={i} />
      ))}
    </div>
  );
}
ログイン後にコピー

現在、コンポーネント内で何も呼び出すことができないことがわかります。 setter 関数は、状態を変更できないことを意味します。このコンポーネントでは、状態を変更するためのロジックを含める必要はなくなりました。これらのロジックは

useRepos

フック関数に含まれています。もちろん、本当に必要な場合は、フック関数の return ステートメントで公開できます。 これを行うことでどのようなメリットがあるのでしょうか? React のドキュメントには次のように記載されています:

カスタム フック関数を抽出することで、コンポーネント ロジックを再利用できます

このアプリケーションの他のコンポーネントもウェアハウス内のユーザー リストを表示する必要がある場合、このコンポーネントが行う必要があるのは、useRepos フック関数をインポートすることだけであると簡単に想像できます。おそらく何らかの形式のキャッシュを使用してフックが更新される場合、またはポーリングまたはより複雑なアプローチによって継続的に更新される場合、このフックを参照するすべてのコンポーネントが恩恵を受けます。

もちろん、カスタム フックの抽出には、再利用が容易になるだけでなく、他の利点もあります。この例では、すべての useStateuseEffect は同じ機能、つまりライブラリ ユーザー リストを取得することを目的としています。これをアトミック関数とみなします。コンポーネントには、そのようなアトミック関数を多数含めることができます。これらのアトミック関数のコードを別のカスタム フック関数に抽出すると、コード ロジックを変更するときにどの状態を同期的に更新する必要があるかを見つけることが容易になり、見逃される可能性が低くなります。さらに、これを行うことの利点は次のとおりです。

  • 関数が短いほど、理解しやすくなります
  • アトミック関数に名前を付ける機能 (useRepo など)
  • ドキュメントをより自然に提供します (各カスタムフック関数の機能がよりまとまって単一になり、この種の関数はコメントも書きやすくなります)

最後に

#我々 React のフック関数はそれほど神秘的ではなく、他の関数と同じように作成できることを学びましょう。独自のドメイン固有のフックを作成し、アプリケーション全体で再利用できます。また、さまざまなブログや「フック ライブラリ」で、あらかじめ作成された汎用フックが多数見つかります。これらのフックは、

useStateuseEffect などのプロジェクトに簡単に適用できます。 Dan Abramov の useInterval フックは一例です。たとえば、useRepos に似たフックがありますが、更新をポーリングできる必要があるとします。次に、フックで useInterval を使用してみてください。

英語の元のアドレス: https://codescene.com/engineering-blog/refactoring-components-in-react-with-custom-hooks

[推奨学習] :

JavaScript ビデオ チュートリアル ]

以上が[翻訳] カスタムフックを使用した 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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー Dec 17, 2023 pm 05:30 PM

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

PHP と Vue: フロントエンド開発ツールの完璧な組み合わせ PHP と Vue: フロントエンド開発ツールの完璧な組み合わせ Mar 16, 2024 pm 12:09 PM

PHP と Vue: フロントエンド開発ツールの完璧な組み合わせ 今日のインターネットの急速な発展の時代において、フロントエンド開発はますます重要になっています。 Web サイトやアプリケーションのエクスペリエンスに対するユーザーの要求がますます高まっているため、フロントエンド開発者は、より効率的で柔軟なツールを使用して、応答性の高いインタラクティブなインターフェイスを作成する必要があります。フロントエンド開発の分野における 2 つの重要なテクノロジーである PHP と Vue.js は、組み合わせることで完璧なツールと見なされます。この記事では、PHP と Vue の組み合わせと、読者がこれら 2 つをよりよく理解し、適用できるようにするための詳細なコード例について説明します。

フロントエンドの面接官からよく聞かれる質問 フロントエンドの面接官からよく聞かれる質問 Mar 19, 2024 pm 02:24 PM

フロントエンド開発のインタビューでは、HTML/CSS の基本、JavaScript の基本、フレームワークとライブラリ、プロジェクトの経験、アルゴリズムとデータ構造、パフォーマンスの最適化、クロスドメイン リクエスト、フロントエンド エンジニアリング、デザインパターン、新しいテクノロジーとトレンド。面接官の質問は、候補者の技術スキル、プロジェクトの経験、業界のトレンドの理解を評価するように設計されています。したがって、候補者はこれらの分野で自分の能力と専門知識を証明するために十分な準備をしておく必要があります。

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 Dec 17, 2023 pm 05:13 PM

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 Jan 05, 2024 pm 06:08 PM

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

Django はフロントエンドですか、バックエンドですか?それをチェックしてください! Django はフロントエンドですか、バックエンドですか?それをチェックしてください! Jan 19, 2024 am 08:37 AM

Django は、迅速な開発とクリーンなメソッドを重視した Python で書かれた Web アプリケーション フレームワークです。 Django は Web フレームワークですが、Django がフロントエンドなのかバックエンドなのかという質問に答えるには、フロントエンドとバックエンドの概念を深く理解する必要があります。フロントエンドはユーザーが直接対話するインターフェイスを指し、バックエンドはサーバー側プログラムを指し、HTTP プロトコルを通じてデータと対話します。フロントエンドとバックエンドが分離されている場合、フロントエンドとバックエンドのプログラムをそれぞれ独立して開発して、ビジネス ロジックとインタラクティブ効果、およびデータ交換を実装できます。

Go 言語のフロントエンド テクノロジーの探求: フロントエンド開発の新しいビジョン Go 言語のフロントエンド テクノロジーの探求: フロントエンド開発の新しいビジョン Mar 28, 2024 pm 01:06 PM

Go 言語は、高速で効率的なプログラミング言語として、バックエンド開発の分野で広く普及しています。ただし、Go 言語をフロントエンド開発と結びつける人はほとんどいません。実際、フロントエンド開発に Go 言語を使用すると、効率が向上するだけでなく、開発者に新たな視野をもたらすことができます。この記事では、フロントエンド開発に Go 言語を使用する可能性を探り、読者がこの分野をよりよく理解できるように具体的なコード例を示します。従来のフロントエンド開発では、ユーザー インターフェイスの構築に JavaScript、HTML、CSS がよく使用されます。

Django: フロントエンド開発とバックエンド開発の両方を処理できる魔法のフレームワークです。 Django: フロントエンド開発とバックエンド開発の両方を処理できる魔法のフレームワークです。 Jan 19, 2024 am 08:52 AM

Django: フロントエンド開発とバックエンド開発の両方を処理できる魔法のフレームワークです。 Django は、効率的でスケーラブルな Web アプリケーション フレームワークです。 MVCやMTVなど複数のWeb開発モデルをサポートし、高品質なWebアプリケーションを簡単に開発できます。 Django はバックエンド開発をサポートするだけでなく、フロントエンド インターフェイスを迅速に構築し、テンプレート言語を通じて柔軟なビュー表示を実現します。 Django はフロントエンド開発とバックエンド開発をシームレスに統合するため、開発者は学習に特化する必要がありません。

See all articles