2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【React状態管理1】状態管理とは

Posted at

概要

Reactの状態管理について学んだことを共有します。
本稿では状態管理の全体像の話ですが、今後、各状態管理ライブラリの使い方について投稿する予定です。

学習内容

状態管理とは

プロジェクト内のデータを専用の領域で保持・管理したもの(React Hooksでよく使われるuseStateも単一コンポーネントでの状態管理と言える)。
状態管理を使わなくても設計は可能だが、複数のコンポーネントでデータを活用する場合、下記のようにバケツリレー的にデータの受け渡しが必要となり、コードが煩雑になる。
そのため、規模の大きなプロジェクトほど、状態管理が重要となる。

Reactのバケツリレー1

データ受け渡しのバケツリレー

状態管理のライブラリの種類

状態管理のライブラリは複数あるが、それぞれ一長一短があり、主流と言えるライブラリはない。そのため、状況に応じて利用するライブラリを選定する必要がある。

ライブラリ名 内容 ReactAPI? ベース
useContext Reactの公式フック Yes
Redux これまで最も主流。非常に有用だが、概念理解が難しい。 Yes state machine based
Zustand シンプルで使いやすい No state machine based
XState ステートマシンを実装するのに特化したライブラリ。状態遷移の制御が容易 state machine based
Recoil Meta社が開発したライブラリ。 Yes atom based
Jotai サイズが軽量で利用が比較的容易 Yes atom based
valtio Poimandresが開発しているライブラリ No atom based

atom-based:状態を個別に管理する
state machine based:全体を一つの状態として管理する

参考

IT Kingdom
状態管理とは

  1. Rectの状態管理のベストは!?より引用

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?