Redux reducers将嵌套对象添加到状态

时间:2017-02-08 00:34:40

标签: javascript reactjs redux state

在使用React / Redux为我的应用制作用户界面的同时,将我的头撞在墙上。问题是,当我的操作被客户端变异状态触发时,它会将状态改变为嵌套对象。

在这种情况下,我正在尝试将状态loginForm的部分更改为"login""signUp"。当我解雇我的行动时,道具loginForm(从状态传递到我的组件中)看起来像这样:this.props.loginForm.loginForm = "login"

客户端代码:

import React from "react";

    import LoginForm from "../minor/LoginForm";

    const Login = React.createClass({

      displayForm(){

        if (this.props.loginForm === "login"){
          return <span>Login</span>
        } else if (this.props.loginForm === "signUp"){
          return <span>Sign Up</span>
        } else {
          console.log("meh")
        }

      },

      renderLogin(){
        this.props.chooseForm("login");
      },

      renderSignUp(){
        this.props.chooseForm("signUp");
      },

      render(){

        return(

            <div className="loginBox">
              <h1>Slots</h1>
              <button onClick={this.renderLogin}  name="login" >Login</button>
              <button onClick={this.renderSignUp} name="signUp" >Sign Up</button>            
              {this.displayForm()}
            </div>
          )
      }
    });

    export default Login;

userActions.js

export function chooseForm(form){
  console.log("choosing form")

  return {
    type: "CHOOSE_FORM",
    form
   }
}

userReducer.js

export function loginForm(state=null, action){

  switch(action.type){

  case "CHOOSE_FORM":

    return {...state, loginForm: action.form };


  default:
    return state;
  }
}

此处的目的是显示与this.prop.loginForm的值相关联的正确组件,由于我上述问题,该组件无法实现。

更新

mainReducer.js(combinedReducer)

import {combineReducers} from "redux";
import {routerReducer} from "react-router-redux";

// reducers
import { loginStatus, loginForm }from "./userReducer";

const rootReducer = combineReducers({ loginStatus, loginForm, routing:      routerReducer});

 export default rootReducer;

2 个答案:

答案 0 :(得分:2)

如果没有看到你的其余代码,我会做出有根据的猜测,并说这看起来可能是CombinedReducers文件中的一个问题。如果你正在使用combineReducers阅读......

可能是因为你将Redux状态设置为:

loginForm: userReducer
// so the Redux state would be set have a property in it
// 'loginForm' set to {loginForm:'login'}

解决方案:

将combineReducers修改为:

loginForm: userReducer.loginForm

答案 1 :(得分:1)

因为你的loginForm reducer是slice reducer,你应该只返回该状态片的值,而不是整个状态,即你应该返回form值:

case "CHOOSE_FORM": 
    return action.form;

在处理这些操作时,会使用loginForm"login"替换"signUp"状态键。