React-redux Update Item In Array Doesn't Re-render
I have a reducer which returns an object with an array in the object. I render the list of items in the array and when the user clicks on that item I want to re-render the array (
Solution 1:
State in redux is immutable. This means that reducer should create a new state for every mutation. Preferably, a deep clone should be done when arrays are present. The following code does an approximate deep clone for your code to work. Try utilities like lodash/deepClone for an easier solution.
const counter = (state = {count:0, history:[]}, action) => {
let {count} = state;
let history = [...state.history];
switch (action.type) {
case 'SELECT':
history[action.i].selected = true;
break;
case 'INCREMENT':
history.push({count,selected:false});
count++;
break;
case 'DECREMENT':
history.push({count,selected:false});
count--;
break;
default:
break;
}
console.log("count reducer: ", {count,history})
return {count,history};
}
Post a Comment for "React-redux Update Item In Array Doesn't Re-render"