検索
ホームページウェブフロントエンドjsチュートリアルリダックスは死んだのか?私が SaaS アプリから Redux を排除した理由

Is Redux Dead? Why I Kicked Redux Out of Our SaaS App

?接続: https://www.subham.online

?Twitter: https://twitter.com/TheSubhamMaity


数か月前、私は思い切って、しばらく取り組んできた SaaS アプリの一部をリファクタリングしました。そこには Redux があり、グローバル状態を管理する役割を果たしていました。しかし、何か違和感を感じました。コードベースが大きくなり、Redux が重く感じ始めました。何ヶ月も触っていなかったものをバックパックに入れて持ち歩くときなどはどうでしょうか?そんな感じでした
しかし、アプリが成長するにつれて、複雑さも増してきました。 Redux は解決策というよりはむしろ問題のように感じられるようになりました。私たちは実際のロジックより定型的なものを書いていました。

? Redux のジレンマ

ある日、Redux 関連の別のバグと格闘しているときに、React Query に出会いました。いくつか調べた結果、React Query に出会いました。これについてはよく噂を聞いていましたが、Redux を完全に置き換えることができるとは思いもしませんでした。そこで、試してみました。

前 (Redux 使用):

// Action
const fetchUserData = (userId) => async (dispatch) => {
  dispatch({ type: 'FETCH_USER_REQUEST' });
  try {
    const response = await api.fetchUser(userId);
    dispatch({ type: 'FETCH_USER_SUCCESS', payload: response.data });
  } catch (error) {
    dispatch({ type: 'FETCH_USER_FAILURE', error });
  }
};

// Reducer
const userReducer = (state = initialState, action) => {
  switch (action.type) {
    case 'FETCH_USER_REQUEST':
      return { ...state, loading: true };
    case 'FETCH_USER_SUCCESS':
      return { ...state, loading: false, data: action.payload };
    case 'FETCH_USER_FAILURE':
      return { ...state, loading: false, error: action.error };
    default:
      return state;
  }
};

// Component
const UserProfile = ({ userId, fetchUserData, userData, loading, error }) => {
  useEffect(() => {
    fetchUserData(userId);
  }, [userId]);

  if (loading) return <spinner></spinner>;
  if (error) return <error message="{error.message}"></error>;
  return <userinfo user="{userData}"></userinfo>;
};

const mapStateToProps = (state) => ({
  userData: state.user.data,
  loading: state.user.loading,
  error: state.user.error,
});

export default connect(mapStateToProps, { fetchUserData })(UserProfile);

後 (React Query を使用):

const useUserData = (userId) => {
  return useQuery(['user', userId], () => api.fetchUser(userId));
};

const UserProfile = ({ userId }) => {
  const { data, isLoading, error } = useUserData(userId);

  if (isLoading) return <spinner></spinner>;
  if (error) return <error message="{error.message}"></error>;
  return <userinfo user="{data}"></userinfo>;
};

export default UserProfile;

手動でデータをフェッチし、リデューサーを作成し、アクションをディスパッチしてからストアを更新する代わりに、React Query がその重労働のほとんどを私たちのために行ってくれました。これにいくつかの巧妙に作成されたカスタム フックを組み合わせると、無駄のない平均的な状態管理マシンが完成しました。

?しかし、待ってください、Redux はすべて悪いものなのでしょうか?

さて、誤解しないでください。 Redux はブギーマンではありません。これは、適切な場所を持った強力なツールです。多くの無関係なコンポーネント間で共有する必要がある複雑なクライアント側の状態を含むアプリを構築している場合、深くネストされた状態を使用している場合、またはアプリのフローをより明示的に制御する必要がある場合。 % のケース、特にサーバー状態の処理には、React Query カスタム フックで十分です。

では、なぜ大騒ぎするのでしょうか?開発者として、私たちは、より優れたツールがあるにもかかわらず、使い慣れたものを使用するという罠に陥ることがあります。それが私と Redux で起こったことです。私は古いやり方に囚われており、大規模なアプリの状態を管理するには Redux が唯一の方法だと考えていました。つまり、インターネット全体が「Redux かバストか!」と言っていたのです。そうですよね?

?どんでん返し

これがキッカーです。Redux を削除することで、実際にアプリのスケーラビリティがさらに向上しました。直感に反しますよね?しかし、考えてみてください。React Query がサーバーの状態を処理し、カスタム フックがローカルの状態を管理することで、懸念事項が明確に分離されました。アプリの各部分はよりモジュール化され、推論が容易になりました。

?リダックスは死んだのか?

正直に言うと、ここ数か月間、React Query が私のニーズを満たさないケースはほとんどありませんでした。

では、Redux は死んだのでしょうか?そうではないかもしれないが、かつてのようなオールスターではないことは確かだ。最新の React アプリでサーバー状態を処理するため

それで、これで終わりです。 Redux 中毒から React Query の啓発までの私たちの旅。それは必ずしも簡単なことではありませんでした。疑問が生じたり、深夜のデバッグ セッションが必要になったり、何度もフェイスパームをすることもありました。しかし、最終的にはそれだけの価値がありました。

自分のアプリで Redux に行き詰まっていると感じている場合は、一歩下がって自問することをお勧めします。「本当に必要ですか?」あなたはその答えに驚かれるかもしれません。

少ない方が良い場合もあります。特に状態管理に関してはそうです。すみません、削除するリデューサーがまだいくつかあります。コーディングを楽しんでください!

以上がリダックスは死んだのか?私が SaaS アプリから Redux を排除した理由の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
JavaScriptとWeb:コア機能とユースケースJavaScriptとWeb:コア機能とユースケースApr 18, 2025 am 12:19 AM

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

JavaScriptエンジンの理解:実装の詳細JavaScriptエンジンの理解:実装の詳細Apr 17, 2025 am 12:05 AM

JavaScriptエンジンが内部的にどのように機能するかを理解することは、開発者にとってより効率的なコードの作成とパフォーマンスのボトルネックと最適化戦略の理解に役立つためです。 1)エンジンのワークフローには、3つの段階が含まれます。解析、コンパイル、実行。 2)実行プロセス中、エンジンはインラインキャッシュや非表示クラスなどの動的最適化を実行します。 3)ベストプラクティスには、グローバル変数の避け、ループの最適化、constとletsの使用、閉鎖の過度の使用の回避が含まれます。

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

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

Python vs. JavaScript:コミュニティ、ライブラリ、リソースPython vs. JavaScript:コミュニティ、ライブラリ、リソースApr 15, 2025 am 12:16 AM

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

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エンジン:実装の比較JavaScriptエンジン:実装の比較Apr 13, 2025 am 12:05 AM

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

ブラウザを超えて:現実世界のJavaScriptブラウザを超えて:現実世界のJavaScriptApr 12, 2025 am 12:06 AM

現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

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

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

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SublimeText3 Mac版

SublimeText3 Mac版

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

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、