質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.81%

Reduxで初期値が取得できない。

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 527

HarumakiLove

score 8

前提

数字のカウンターを作成してReduxを学習しています。
下記はサンプルです。

サンプル(CodeSandBox)

サンプルのコードは、下記の動画を参考にして制作しました。
【React Redux】React Redux入門編!20分弱の動画で、React Reduxが学べる!?日本語で詳しく解説!(YouTube)

問題点

countの初期値0を所得出来ず、現状は下図の通り「count: 」と表示されます。
イメージ
console.log(count)で確認したところ、undefinedでした。

実現したいこと

初期値である0を取得して、「count: 0」と表示させたいです。

使用しているライブラリ

  • Redux
  • React-Redux

TypeScriptも使用しています。

ソースコード

index.tsx

import * as React from "react";
import { render } from "react-dom";
import { createStore } from "redux";
import { Provider } from "react-redux";
import counter from "./reducers/counter";

import App from "./App";

let store = createStore(counter);

const rootElement = document.getElementById("root");
render(
  <Provider store={store}>
    <App />
  </Provider>,
  rootElement
);

App.tsx

import * as React from "react";
import { increment, decrement } from "./actions/counter";
import { useSelector, useDispatch } from "react-redux";

export default function App() {
  const count = useSelector((state: { count: number }) => state.count);
  const dispatch = useDispatch();

  return (
    <>
      <h1>count: {count}</h1>
      <button onClick={() => dispatch(increment())}>+</button>
      <button onClick={() => dispatch(decrement())}>-</button>
    </>
  );
}

reducers/counter.ts

const counter = (count = 0, action: { type: string }) => {
  switch (action.type) {
    case "INCREMENT":
      return count + 1;
    case "DECREMENT":
      return count - 1;
    default:
      return count;
  }
};

export default counter;

actions/counter.ts

export const increment = () => {
  return {
    type: "INCREMENT"
  };
};

export const decrement = () => {
  return {
    type: "DECREMENT"
  };
};

現状のコードに対する認識レベルや私なりに推測した原因

  • reducer/counter.ts
const counter = (count = 0, action: { type: string }) => {

count = 0で初期値を設定できている

  • countがundefinedになっているので、初期値ではなくcountそのものが取得できていない?
  • reducerを見るにactionをdispatchすることでcountが返ってくるので、actionをdispatchするまではcountは存在しない?

試したこと

サンプルを作成するにあたり参考にした動画の通り、combineReducersを経由させることで初期値を取得することができました。

reducers/reducers.ts

import { combineReducers } from "redux";
import counter from "./counter";

const reducers = combineReducers({
  count: counter 
});

export default reducers;

しかし現状reducerは1つなのと、combineReducersを経由させるとなぜ初期値が取得できるか理解できていないので、combineReducersを使用しない場合の実装方法をご教示いただきたいです。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+2

こんにちは

以下のように修正してみると、いかがでしょうか?

- const count = useSelector((state: { count: number }) => state.count);
+ const count = useSelector((count: number) => count);

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+1

createStore では最初は reducer を呼び出さずに第二引数で渡されたものを initialState とする(第二引数が省略されたら undefined になる)のに対して、combineReducers は各 reducer を state = undefined で呼び出した結果を intialState にするから、だと思います。

参考: ReduxでReducerとInitialStateを分けるためのbetterCombineReducers - Qiita

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.81%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る