⊗jsrxPmWFRAA 17 of 57 menu

Reduxのレデューサーとアクション

前回のレッスンでは、商品を追加するためのフォームを完成させ、 メインページに表示しました。しかし、現在追加されたデータは保存されず、 つまり新しい商品はストア内の既存商品に追加されません。 これを修正しましょう。

まず、商品アプリケーションでファイル productsSlice.jsx を開き、 createSlicereducer プロパティ内に、 渡された現在の状態とアクションに基づいてストアに商品を追加する productAdded 関数を記述します。 ここで渡されるのは state 全体ではなく、商品を担当する部分のみであることに 注意してください(products スライスはそれのみを知っています)。 新しい商品のオブジェクトは、フォームの保存ボタンが押されたときに ハンドラーによって生成される action オブジェクトの payload プロパティに含まれます。 結果として、レデューサー productAddedcreateSlice のコード内で次のようになります:

const productsSlice = createSlice({ name: 'products', initialState, reducers: { productAdded(state, action) { state.push(action.payload) }, }, })

アクションについてはどうでしょうか? チュートリアルの最初の方で、アクションはアプリケーションで発生した事象を記述する オブジェクトとして表現されるものであることに触れました。 また、次のようなアクションオブジェクトを作成する アクションクリエーター関数を使用できることも話しました:

const addProduct = newProduct => { return { type: 'products/productAdded', payload: newProduct } }

良いニュースは、私たちが使用している createSlice 関数が この作業を代わりに行ってくれることです。 レデューサーを記述すると、この関数は自動的に同じ名前の アクションクリエーターを作成してくれます。 私たちは、コンポーネントで使用するために得られたアクションクリエーターを エクスポートするだけです。 ファイルの最後、レデューサーをエクスポートする前に次のように行いましょう:

export const { productAdded } = productsSlice.actions export default productsSlice.reducer

学生アプリケーションを開き、ファイル studentsSlice.jsx を開いて、 レッスンで示した通りに createSlicereducer フィールドの値を追加してください。

ファイル studentsSlice.jsx の最後に、 得られたアクションクリエーター関数のエクスポートを追加してください。

日本語
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItalianoქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
当サイトでは、サイトの動作、分析、パーソナライゼーションのためにクッキーを使用しています。 データ処理はプライバシーポリシーに従って行われます。
すべて受け入れる 設定 拒否