Javascript 通过复选框在Redux状态下切换True和False

Javascript 通过复选框在Redux状态下切换True和False,javascript,reactjs,redux,Javascript,Reactjs,Redux,此处的总反应/还原noob;在我的应用程序中,我有一个表单复选框,可以在我的状态中将选项设置为true或false 这是我的复选框-我不确定如何正确设置此真/假标志: <input type="checkbox" onChange={ (e) => this.props.dispatch(setOption({'currentAddress': [true/false flag]})) } defaultChecked={ true } /> 和减速器: co

此处的总反应/还原noob;在我的应用程序中,我有一个表单复选框,可以在我的状态中将选项设置为true或false

这是我的复选框-我不确定如何正确设置此真/假标志:

<input 
  type="checkbox" 
  onChange={ (e) => this.props.dispatch(setOption({'currentAddress': [true/false flag]})) }
  defaultChecked={ true }
/>
和减速器:

const initialState = {
  formOptions {
    currentAddress: true,
    isEmployed: true,
    // ...
  }
}

const Reducer = (state = initialState, action) => {
  switch (action.type) {
    case SET_OPTION:
      let option = action.payload
      return { ...state.formOptions, option};
    default:
    return state;
  }
}
我的问题是:

  • 在我的状态下,如何在true和false之间切换选项
  • 我以后如何在代码中引用此选项?
    getState()
    是标准方式吗
欢迎您的任何意见

1)

如果您商店的初始状态为

{
  formOptions: {
    currentAddress: true,
    isEmployed: true
    // ...
  }
}
然后在减速器中不要返回

{
  ...state.formOptions
}
因为这将返回与初始结构不同的状态

{
  currentAddress: true,
  isEmployed: true
  // ...
}
阅读此处有关排列操作员行为的信息:

相反,你的减速器应该看起来像

const reducer = (state = initialState, action) => {
  switch (action.type) {
    case SET_OPTION:
      return {
        ...state, // copy data in state other than formOptions
        formOptions: {
          ...state.formOptions, // copy other formOptions
          ...action.payload // here you are overwriting the 'currentAddress' property since action.payload = { 'currentAddress': true/false }
        }
      };
    default:
      return state;
  }
};
Reducer只是一个函数,它接受
状态
并返回新的
状态
:)

(二)

您可能希望将Redux存储与React组件绑定,以便能够在React组件props中传递Redux数据。此处提供了完整的说明:

const reducer = (state = initialState, action) => {
  switch (action.type) {
    case SET_OPTION:
      return {
        ...state, // copy data in state other than formOptions
        formOptions: {
          ...state.formOptions, // copy other formOptions
          ...action.payload // here you are overwriting the 'currentAddress' property since action.payload = { 'currentAddress': true/false }
        }
      };
    default:
      return state;
  }
};