[解決済み] reduxを使用してアイテムを削除する方法はこれでよいのでしょうか?
2022-02-17 17:10:29
質問
入力に変異を与えてはいけないことは知っていますし、変異させるにはオブジェクトをクローンする必要があります。私は、reduxスタータープロジェクトで使われていた慣習に従っていました。
ADD_ITEM: (state, action) => ({
...state,
items: [...state.items, action.payload.value],
lastUpdated: action.payload.date
})
項目を追加するために、spread を使用して配列に項目を追加しています。
を削除に使用しました。
DELETE_ITEM: (state, action) => ({
...state,
items: [...state.items.splice(0, action.payload), ...state.items.splice(1)],
lastUpdated: Date.now()
})
しかし、これは入力状態オブジェクトを変異させていることになります。新しいオブジェクトを返しているにもかかわらず、これは禁止されているのでしょうか?
解決方法は?
いいえ、決して状態を変異させないでください。
新しいオブジェクトを返すとはいえ、古いオブジェクトを汚染することになるわけで、これは絶対に避けたいことです。これは、古い状態と新しい状態を比較するときに問題になります。例えば
shouldComponentUpdate
react-reduxがフードの下で使っているものです。また、タイムトラベル(元に戻す、やり直す)も不可能になります。
代わりに、イミュータブルメソッドを使用します。常に
Array#slice
であり、決して
Array#splice
.
あなたのコードから推測すると
action.payload
は削除される項目のインデックスです。よりよい方法は、次のようになります。
items: [
...state.items.slice(0, action.payload),
...state.items.slice(action.payload + 1)
],
関連
-
[解決済み] [Solved] Uncaught TypeError: nullのプロパティ 'appendChild' を読み取ることができない。
-
[解決済み】TypeError: res.status は関数ではありません。
-
[解決済み] let "と "var "の使い分けは?
-
[解決済み] JavaScriptでオブジェクトをディープクローンする最も効率的な方法は何ですか?
-
[解決済み] セレクタの子を取得する方法は?
-
[解決済み] モバイル端末の検出にはどのような方法がありますか?
-
[解決済み] JavaScriptでページの一番上までスクロールする?
-
[解決済み] コールバック内で正しい `this` にアクセスする方法
-
[解決済み] 配列の最後の項目を取得する
-
[解決済み] ES6 ジェネレータで redux-saga を使用する利点/欠点と ES2017 async/await で redux-thunk を使用する利点/欠点
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】 Uncaught TypeError: data.push is not a function
-
[解決済み】XMLHttpRequestモジュールが定義されていない/見つからない
-
[解決済み】SyntaxError: 'import' と 'export' は 'sourceType: module' とだけ表示されるかもしれない - Gulp
-
[解決済み】React.jsの配列の子要素のユニークキーを理解する
-
[解決済み】npm install --legacy-peer-deps は具体的に何をするのですか?どんなときに推奨されるのか/どんな使用例が考えられるのか?
-
[解決済み】PhantomJS 2.1.1を使用してReactJSアプリケーションをレンダリングできない理由とは?
-
[解決済み】ES6マップオブジェクトをソートすることは可能ですか?
-
[解決済み】 Uncaught Reference Error: stLight is not defined (in Chrome only)
-
[解決済み】TypeError: AngularJSで未定義のプロパティ'get'を読み取れない
-
[解決済み] Uncaught (in promise) TypeError: フェッチに失敗してCorsエラー