javascript - 单击 react 中的提交按钮迁移到新组件

标签 javascript reactjs

有人可以建议如何在单击提交按钮时迁移到新组件吗?我正在使用 react 制作一个简单的登录页面。包含电子邮件字段和提交按钮,我尝试的是如果我输入电子邮件并单击提交,则会出现密码组件。即与 Gmail 登录相同。

最佳答案

按如下方式创建主要组件。

export default class Index extends React.Component{

  constructor(props) {
    super(props);
    this.state = {
        currentStep : 1,
    };
    this.changeStep = this.changeStep.bind(this);
}

loadSteps() {
    switch(this.state.currentStep) {
        case 1:
            return (<EmailView />);
        case 2:
            return  (<PasswordView />);
        default:
            return (<EmailView />);
    }
}

changeStep(step) {
    this.setState({ currentStep : step});
}

render() {

    return (
        <div className="login-steps-container">
             {this.loadSteps()}
        </div>
    );
}

}

并为电子邮件字段和密码步骤创建两个子组件,

Email.js

export default class Email extends React.Component{

  constructor(props) {
    super(props);
  }

  render() {

    return (
        <div className="email-step" >
            <input type="text" className="email-field">
            <input type="button" value="Go to" onClick="this.props.changeStep.bind(this, 2)">
        </div>
    );
  }
}

密码.js

export default class Password extends React.Component{

  constructor(props) {
    super(props);
  }

  render() {

    return (
        <div className="password-step" >
            <input type="password" className="password-field">
            <input type="button" value="Login" >
        </div>
    );
  }
}

关于javascript - 单击 react 中的提交按钮迁移到新组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40718428/

相关文章:

javascript - 无法为所有列标题绑定(bind)单击事件。只能工作一次

css - 如何在带有 borderRadius 的 View 组件中放置两个 View 组件?

javascript - 为什么它给我 'Cannot read property ' deleteProduct' of undefined' 错误 react Js

javascript - 如何在 react 表中进行默认排序

javascript - 在我的沙箱中渲染数据的 redux 方式不成功

javascript - 服务器应该如何响应 Backbone 同步

javascript - 我不太擅长编码,并且我的 Hangman 游戏遇到一些问题

javascript - 为什么 IE 以外的浏览器中 DOM Document 对象中缺少 XML 属性

javascript - 如何检查一个字符串的所有字符是否都存在于另一个字符串中?

reactjs - React 的 CDN 与 Webpack