javascript - redux 获取输入文本值

标签 javascript reactjs redux react-redux

我有以下reactjs组件。

class Login extends Component {

render() {
    if (this.props.session.Authenticated) {
        return (
            <div></div>
        );
    }
    return (
        <div>
            <input type="text" placeholder="Username" />
            <input type="password" placeholder="Password" />
            <input
                type="button"
                value="Login"
                onClick={() => this.props.LoginAction("admin", "password")}
             />
        </div>
    );
}
}

Login 组件使用通过 redux 设置的名为“session.Authenticated”的 prop。如果用户 session 未经身份验证,我会显示几个输入字段(一个用于用户名,另一个用于密码)和一个登录按钮。如果我按下 Login 按钮,我想发出一个带有用户名和密码值的操作,并作为参数传递。现在,如何获取参数的两个输入字段的值?

IOW,我想用两个输入字段的值删除上面代码中硬编码的“admin,password”。如何实现这一目标?

所有示例都指向 redux-form,这是我不想添加的新依赖项。我希望将依赖关系保持在最低限度,因此在我的项目中仅使用react、redux 和react-redux。

最佳答案

类似这样的事情:

  class Login extends Component {
     constructor(props){
        super(props);
        this.state = {
           model = {
              login: "",
              password: ""
           }
        }
     }
  render() {
      if (this.props.session.Authenticated) {
        return null;
    }
    return (
        <div>
            <input type="text" value={this.state.model.value.login} onChange={e => this.updateModel(e.target.value, 'login')}placeholder="Username" />
            <input type="password" value={this.state.model.password }onChange={e => this.updateModel(e.target.value, 'password')} placeholder="Password" />
            <input
                type="button"
                value="Login"
                onClick={() => this.props.LoginAction(this.state.model.login, this.state.model.password)}
             />
        </div>
    );
}

 updateModel(value, name){
    var model = extend({}, this.state.model);
    model[name] = value;
    this.setState({model});
  }
}

关于javascript - redux 获取输入文本值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40521333/

相关文章:

reactjs - GraphQL错误: Expected type Int. Int不能表示非整数值

javascript - 更新 redux store 中的嵌套数据

javascript - 如何使用 AMPLE SDK 缩放和平移嵌入 XHTML 页面的 SVG 文档

ios - 扩展 RCTConvert 以提供自定义函数类型

javascript - 更改 React 中 onChange 的 props

javascript - Firebase onAuthStateChanged 在登录时被调用两次

redux - 是否可以在切片 reducer 中重新分配整个状态(使用 Redux ToolKit)?

javascript - 如何向变量的内容添加新内容,然后替换该变量?

javascript - 使用 php 将地址从 mysql DB 读取到数组中进行地理编码

javascript - 同一元素的 CSS3 多重过渡