還元状態から要素を削除します。イムはシームレスで不変で、そのAPIを使って状態を操作します。しかし、状態がネストされている場合、要素を削除するための見栄えの良い方法は見つかりませんでした。ネストされた還元状態から要素を削除します
だから私は削除したい要素がある: state.shoppingcartReducer.products[articleNr]
ありがとう!
import Immutable from 'seamless-immutable'
import { addToShoppingcart, createShoppingCart } from '../actions/shoppingcartActions'
const CREATE_SHOPPING_CART = 'CREATE_SHOPPING_CART'
const ADD_PRODUCT = 'ADD_PRODUCT'
const DELETE_PRODUCT = 'DELETE_PRODUCT'
const UPDATE_QUANTITY = 'UPDATE_QUANTITY'
const SUMMARY = 'SUMMARY'
const initialState = Immutable({
summary: {
sum: 0,
quantity: 0
}
})
export default function shoppingcartReducer(state = initialState, action) {
switch (action.type) {
case ADD_PRODUCT:
return state
.setIn(['products', action.product.articleNr], addArticle(action))
// case DELETE_PRODUCT:
// return ??
case SUMMARY:
return state
.set('summary', calculateSums(action, state))
case CREATE_SHOPPING_CART:
return state
.set(action.id, createCart(action))
case UPDATE_QUANTITY:
return state.
set('summary', calculateQuantity(action, state))
}
return state
}
function addArticle(action) {
return {
product: action.product
}
}
function calculateQuantity(action, state) {
return {
quantity: state.summary.quantity + action.quantity
}
}
function calculateSums(action, state) {
return {
sum: state.summary.sum + action.price,
quantity: state.summary.quantity + action.quantity
}
}
function calculateSumsDelete(action, state) {
return {
sum: state.summary.sum - action.product.price,
quantity: state.summary.quantity - action.product.quantity
}
}
function createCart(action) {
return {
id: action.id,
}
}
すごい、ありがとう! 'シームレス不変'から '不変'への唯一のことは、私のアプリケーションで自分の状態を読み出すために.get()関数を使用しなければならなくなり、これは多くの問題を引き起こしているということです。マップの代わりに通常のjsオブジェクトとして状態を返すためのハックはありますか? – AlfredO
yup ...そのハックではありません.. map.toJS()を使用してマップをObjectに戻すことができます。 –