React-Redux:连接到状态数组时无限循环?

React-Redux: Infinite loop when concat to an array in state?

所以我正在尝试将元素添加到我存储在状态中的数组中。我知道你不应该直接改变状态,所以我发现使用 concat 是最好的方法。

但是,当我尝试这样做时,出现了无限循环。

reducer.js:

const initialState = {
  name : null, //puzzle name
  start : []
};

export default createReducer(initialState,{
  [START_PROCESS]: (state,payload) => {
    return Object.assign({},state,{
      start : state.start.concat(['test']);
    })
  }
});

结果是['test','test','test','test'...

例如:

我不知道是什么导致了这种奇怪的行为。据我所知,状态只能通过创建新状态以这种方式修改,因此它无法反馈给自身。

createReducer.js

export function createReducer(initialState, reducerMap) {
    return (state = initialState, action) => {
        const reducer = reducerMap[action.type];

        return reducer
            ? reducer(state, action.payload)
            : state;
    };
}

startAction.js

const START_PROCESS = 'START_PROCESS';
export function startProcess(data) {
  return {
    type : START_PROCESS,
    payload : {
      data : data //where data is a string
    }
  }
}

viewAction.js

...
export default ProcessView extends React.Component {
  render() { return <div>{this.props.actions.startProcess('string')}</div> }
}
export default connect(mapStateToProps,mapDispatchToProps)(ProcessView)

避免状态突变的最好方法肯定是ImmutableJS。在你的情况下,我会说也许你认为你的行为是错误的。您确定它不是在渲染内部调用的吗?