Tech Bytes

短くて分かりやすい技術情報を記事として共有します。みなさんにとって学びになれば幸いです。

Reactのフックと導入されたことによる変化

Reactのフックとは何か

Reactのフック(Hook)は、React 16.8から導入された機能であり、関数コンポーネント内で状態管理やライフサイクルメソッドの利用など、クラスコンポーネントで提供されていた機能を、関数コンポーネントでも利用できるようにするための仕組みです。

主なReactのフックには以下のようなものがあります:

1. useState:
状態を関数コンポーネント内で利用できるようにする。
通常の変数とは異なり、状態を変更するとコンポーネントが再レンダリングされる。

import React, { useState } from 'react';

function Example() {
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>
        Click me
      </button>
    </div>
  );
}

2. useEffect:
レンダリングの後に副作用(APIの呼び出し、購読の設定など)を実行するために使用される。
クラスコンポーネントのcomponentDidMount、componentDidUpdate、componentWillUnmountに相当する。

import React, { useEffect } from 'react';

function Example() {
  useEffect(() => {
    // レンダリング後に実行されるコード
    console.log('Component did mount or update');
    return () => {
      // クリーンアップ関数(componentWillUnmountの代わり)
      console.log('Component will unmount');
    };
  }, []); // 第二引数の空の配列は、マウント時にだけ実行されることを示す
}

3. useContext:
Reactのコンテキストを利用するためのフック。

import React, { useContext } from 'react';

const MyContext = React.createContext();

function Example() {
  const contextValue = useContext(MyContext);
  // contextValueを使って何かをする
}

これらはReactのフックの一部であり、関数コンポーネント内で状態やライフサイクルの概念を導入することができるようにします。
これにより、コンポーネントの記述が簡潔になり、再利用性が向上します。

Reactのコンテキストとは

Reactのコンテキスト(Context)は、Reactアプリケーション内でデータを共有するための仕組みです。
通常、コンポーネントツリーを通じてデータを伝達するためにプロップスが使用されますが、深くネストされたコンポーネントにデータを渡すと煩雑になることがあります。
コンテキストは、これをより簡単にし、コンポーネントのネストの深さにかかわらず、特定のデータを取得できるようにします。

具体的には、React.createContext を使用してコンテキストオブジェクトを作成し、 でデータを提供し、useContext フックを使用してそのデータをコンポーネント内で利用できます。

以下は、簡単な例です:

// コンテキストの作成
const MyContext = React.createContext();

// データを提供する親コンポーネント
function ParentComponent() {
  const sharedData = "This is shared data";

  return (
    <MyContext.Provider value={sharedData}>
      <ChildComponent />
    </MyContext.Provider>
  );
}

// データを利用する子コンポーネント
function ChildComponent() {
  // useContext フックを使用してコンテキストからデータを取得
  const contextData = useContext(MyContext);

  return <p>{contextData}</p>;
}

この例では、ParentComponent が MyContext.Provider を使用してデータを提供し、ChildComponent が useContext(MyContext) を使用してそのデータを取得しています。
このようにすることで、ChildComponent は ParentComponent に直接プロップスを渡さずにデータにアクセスできます。

コンテキストは、テーマの設定、認証情報、言語の設定など、アプリケーション全体で共有する必要があるデータや機能に特に有用です。

Reactにフックが導入されて何が変わったか

Reactにフックが導入される前は、主にクラスコンポーネントが利用され、コンポーネントの状態やライフサイクルメソッドの管理はクラス内で行われていました。
しかし、React 16.8でフックが導入されると、これにより関数コンポーネントでも状態やライフサイクルといった概念を利用できるようになりました。
これによって、いくつかの重要な変化が生じました。

1. コードの簡潔化:
フックを使用することで、コンポーネントのロジックを関数に分割できます。
これにより、同じ機能を持つコードがクラスコンポーネントよりも短く、理解しやすくなります。

2. 再利用性の向上:
フックはロジックを再利用しやすくするため、カスタムフックを作成して関数コンポーネント間で簡単に共有できます。
これにより、コンポーネントのコードをより効果的に再利用できます。

3. クラスコンポーネントの必要性の削減:
フックの導入により、関数コンポーネントがより強力で柔軟になりました。
これにより、クラスコンポーネントを使用する必要性が減り、新しいコンポーネントを作成する際にも関数コンポーネントとフックの組み合わせが主流となりました。

4. 副作用の管理:
useEffect フックを使用することで、クラスコンポーネントのライフサイクルメソッドに相当する処理を関数コンポーネント内で管理できるようになりました。
これにより、API呼び出しや購読の設定などの副作用を処理できます。

5. 関数コンポーネントの機能向上:
フックの導入により、関数コンポーネントが状態を持ち、ライフサイクルメソッドを持つなど、より多くの機能を持つようになりました。
これにより、コンポーネントの設計が柔軟になり、クラスコンポーネントと同等の機能を提供できるようになりました。

総じて、Reactのフックの導入により、コードの簡潔性、再利用性、機能向上が実現され、開発者がより効率的かつ柔軟にReactアプリケーションを構築できるようになりました。

Reactの関数コンポーネントとは

Reactの関数コンポーネントは、Reactコンポーネントの一種で、通常、JavaScriptの関数で構成されます。
関数コンポーネントは、React 16.8以前では状態やライフサイクルメソッドの利用が制限されていましたが、React 16.8で導入されたフック(Hooks)により、これらの機能が関数コンポーネントでも利用可能になりました。

以下は、基本的な関数コンポーネントの例です:

import React from 'react';

// 単純な関数コンポーネント
function MyComponent() {
  return (
    <div>
      <h1>Hello, React Function Component!</h1>
    </div>
  );
}

export default MyComponent;

Reactの関数コンポーネントは、単純なレンダリングを行うだけでなく、フックを使用して状態やライフサイクルといった概念を取り入れることができます。
例えば、useState フックを使用して状態を持つ場合は次のようになります:

import React, { useState } from 'react';

// 状態を持つ関数コンポーネント
function Counter() {
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>Count: {count}</p>
      <button onClick={() => setCount(count + 1)}>Increment</button>
    </div>
  );
}

export default Counter;

このように、関数コンポーネントはシンプルで簡潔な記述が可能であり、React 16.8以降ではフックを利用することで、クラスコンポーネントと同等の機能を提供できるようになりました。
関数コンポーネントは、特にコンポーネントがUIを描画することに焦点を当てた場合や、コンポーネントの再利用性を高めたい場合に便利です。