使用 useReducers 调度功能发送多个动作?

IT技术 javascript reactjs react-hooks use-reducer
2021-05-08 12:58:50

useReducerReact 中使用钩子时,是否可以使用调度函数发送多个动作我尝试将一系列操作传递给它,但这会引发未处理的运行时异常。

明确地说,通常会有一个初始状态对象和一个减速器,如下所示:

const initialState = { message1: null, message2: null }

const messageReducer = (state, action) => {
  switch(action.type) {
    case SET_MESSAGE1:
      return {...state, message1: action.payload.message1}
    case SET_MESSAGE2:
      return {...state, message2: action.payload.message2}
    default:
      throw new Error("Something went wrong!")
  }
}

然后可以像这样使用 useReducers 调度函数处理react应用程序中的状态。

[state, dispatch] = useReducer(messageReducer, initialState)
...
dispatch({type: SET_MESSAGE1: payload: {message1: "setting message1"})
dispatch({type: SET_MESSAGE2: payload: {message2: "setting message2"})

我想要做的是将这两个突变发送到一个数组中,这样我只需要调用一次 dispatch,就像这样:

dispatch([
  {type: SET_MESSAGE1: payload: {message1: "setting message1"},
  {type: SET_MESSAGE2: payload: {message2: "setting message2"}
])

现在我写下来了,我意识到我可以在技术上只编写 reducer 来接受一个数组而不是一个字符串,然后映射到那个数组。但这被认为是一种好的做法吗?

1个回答

如果您只想使用 dispatch 一次:

您可以SET_MULTIPLE在 reducer 中再添加一个开关盒

const messageReducer = (state, action) => {
  switch(action.type) {
    case SET_MESSAGE1:
      return {...state, message1: action.payload.message1}
    case SET_MESSAGE2:
      return {...state, message2: action.payload.message2}
    case SET_MULTIPLE:
      return {...state, ...action.payload } // <---- HERE
    default:
      throw new Error("Something went wrong!")
  }
}

并更改调度是这样的:

dispatch({type: SET_MULTIPLE , payload: {message1: "setting message1" , message2 : "setting message2"})