2
2

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.

今更Recoilの主要機能語ってみた

Last updated at Posted at 2022-04-25

はじめに

Recoilってこんな風に書くんだ。useStateとの違いって何?みたいな部分をこの記事でつかんでいただいたら光栄です。

間違っている部分等あればコメントいただけると助かります。

Recoilとは

Recoilは、FaceBook社(現META社)によって開発された状態管理ライブラリです。
背景としてはContext APIが抱える製薬、問題を解決するためとされています。

Recoil主要機能

RecoilRootってなに?

RecoilRootはRecoilを使用するために定義するものであり、推奨されている配置場所に関してはルートコンポーネントとされています。
これを定義することにより、その子供のコンポーネント内の中でRecoilを使えることになります。

App.tsx
import { RecoilRoot } from "recoil"
import { Components } from "./components" 

function App() 
  return (
    <RecoilRoot>
      <Components />
    </RecoilRoot>
  );
} 

Atomって何?

Atomは簡単に言うと状態の単位となるもの
useStateと同様に値が変化するとコンポーネントは再レンダリングされます。
keyはユニークである必要があり, defaultに初期値を格納します

atom.ts
// 例 名前を入力するようなフォームの場合
export const nameState = atom<string>({
  key: "nameState"
  default: "" 
})
// 例 数字を持つ場合
export const countState = atom<number>({
  key: "countState"
  default: 0
})

Selectorって何?

SelectorはAtomの値を加工した値を返したり、stateの値を新しくして返却することができます。
こちらもAtom同様にkeyはユーニクである必要性があります。

selector.ts
import { selector } from "recoil"
import { countState } from "./Atom.ts"
 
export const countSelector = selector({
  key: "countSelector"
  get: ({ get }) => {
    // 定義したatomの値をgetで呼び出す
    const count = get(countState)
    return count + 1
  }
});  

useRecoilStateってなに?

useRecoilStateはAtomの値を取得、更新できるhooksであり、useStateと同様に最初の要素が、状態の値であり、2番目の要素がset関数となっており、状態の値を更新できます。

ComponentA.tsx
import { useRecoilState } from "recoil"
import { CountState } from "./Atom.ts"

expotr const ComponentA = () => {
  const [count, setCount ] = useRecoilState(CountState)
  // useRecoilStateを使ってatomを呼び出す

  const onClick = () => {
    setCount(count + 1)
 }

    return (
      <button onClick={onClick}>
        カウント
    </button>
    )
}

useSetRecoilStateってなに?

useSetRecoilStateは簡単に言うとset関数だけを実行できる関数です。
状況に応じて使い分けたい場合、例えばこのcomponent内では値の取得はせずに値の変更だけ行いたいなどの場合に大活躍します。

input.tsx
const setName = useSetRecoilState(nameState)

const changeName = (e: React.ChangeEvent<HTMLInput>) => {
   setName(e.target.value);
 };

return <input onChange={onChangeName} placeholder="名前" /> 

useRecoilValueってなに?

useRecoilValueはuseSetRecoilStateと違い、値を呼び出すだけの関数になっており、
変更されたatomの値、selectorで加工した値を呼び出すときに主に使用します。

例 入力した文字数をselectorで加工しcomponentで参照したい場合

atom.ts
export const nameState= atom<string>({
  key: "nameState",
  default: ""
});
selector.ts
export const textLengthSelector = selector({
  key: "textLengthSelector",
  get: ({ get }) => {
  
  const text = get(nameState)
  return text.length
})   
length.tsx

const textCount = useRecoilValue(textLengthSelector)

return <div>入力した文字数は{textCount}</div>

useResetRecoilStateってなに?

useResetRecoilStateは状態をデフォルト値に戻す関数であり、例えば脳死で以下のようなコードを書いたとします。

before

form.tsx
const [name, setName] = useRecoilState(nameState)

const resetButton = () => {
  setName("")
}

return  <button onClick={resetNameState}>リセット</button>

このようにリセットボタンを押すと、formの値をリセットするような処理を書きたい場合、set関数を使って上記のようなコードで実行すると無駄なレンダリングが生じます。しかしuseResetRecoilStateを使えば無駄なレンダリングが生じなくなります。

after

form.tsx
const [name, setName] = useRecoilState(nameState)

const resetNameState = useResetRecoilState(nameState)

return <button onClick={resetNameState}> リセット </button>

さいごに

ここまで読んでくださりありがとうございました。
状態管理ってこんなものなんだーみたいな感じで読んでいただけたら光栄です

2
2
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
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?