🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Redux

Reduxは、JavaScriptアプリケーションの状態を管理するためのオープンソースライブラリです。ReactやAngularで一般的にユーザーインターフェイスの構築に利用されます。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

1回答

3555閲覧

@reduxjs/toolkit におけるreducersで同じような処理を重複して書きたくないがどうしたら良いのか分からない

Test_ks

総合スコア33

Redux

Reduxは、JavaScriptアプリケーションの状態を管理するためのオープンソースライブラリです。ReactやAngularで一般的にユーザーインターフェイスの構築に利用されます。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2021/01/13 07:27

最初にgetPostSuccessでは、20件のPostsを取得しています。
ReadMoreボタンを押下した際に、readMorePostsNextを実行し、追加でデータを取得するようにしています。
(@reduxjs/toolkit を利用しています。)

ですが、最初に取得するgetPostSuccessとreadMorePostsNextが殆ど同じ処理をしている(違うのはState.postsの内容のみ)ので、重複した記述を書かないで済む方法を探しています。

それぞれ、methodになるのですが、重複して書かない方法があれば、ご教授いただけないでしょうか?

typescript

1(method) getPostsSuccess(state: WritableDraft<AllPostApi>, { payload }: PayloadAction<PostLoaded>): void 2(method) readMorePostsNext(state: WritableDraft<AllPostApi>, { payload }: PayloadAction<PostLoaded>): void

typescript

1const postSlice = createSlice({ 2 name: 'postsDisplay', 3 initialState, 4 reducers: { 5 getPostsStart: startLoading, 6 getPostsSuccess(state, { payload }: PayloadAction<PostLoaded>) { 7 const posts = payload 8 state.posts = posts.posts 9 state.nextToken = posts.nextToken 10 state.isLoading = false 11 state.error = null 12 console.log('get Post Success') 13 }, 14 getPostsFailure:loadingFailed, 15 subscribePost(state, { payload }: PayloadAction<Post>) { 16 const post = payload 17 state.posts = [post,...state.posts] 18 state.isLoading = false 19 state.error = null 20 console.log('Subscribe') 21 }, 22 readMorePostsNext(state, { payload }: PayloadAction<PostLoaded>) { 23 const posts = payload 24 state.posts = [...state.posts,...posts.posts] 25 state.nextToken = posts.nextToken 26 state.isLoading = false 27 state.error = null 28 console.log('Read More Success') 29 } 30 } 31})

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ヘルパー関数作ってあげるのがよいのではないんでしょうか。例えばこんな。

TypeScript

1type Mode = 'getPostSuccess' | 'subscribePost' | 'readMorePostsNext' 2 3const resetState = (state_: State, post: Post, mode: Mode): State => { 4 let state = {...state_} 5 if(mode === 'getPostSuccess'){ 6 state.posts = post.posts 7 state.nextToken = post.nextToken 8 }else if(mode === 'subscribePost'){ 9 state.posts = [post.posts,...state.posts] 10 }else{ 11 state.posts = [...state.posts,...posts.posts] 12 state.nextToken = post.nextToken 13 } 14 state.isLoading = false 15 state.error = null 16 17 return state 18} 19

いくらかマシになるかもしれません。

あとは非同期を扱うこんな API がドキュメントにありました。
createAsyncThunk | Redux Toolkit
参考までに。

投稿2021/01/14 10:44

A_kirisaki

総合スコア2853

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問