如何执行在子组件中作为 属性 在反应中引发的功能?

how to execute a function which is evoked in a child component as a property in react?

在我的 app.js 文件中,我包含了一个签名组件,如下所示:

onSignin = () => {
  this.setState({ route: "home" });
};

regFunction = () => {
  this.setState({ route: "registering" });
};

render() {
  return (
    <div>
      <Signin y={this.onSignin} reg={this.regFunction} />
    </div>
  );
}

并且在组件文件 Signin.js 中,我写了以下内容:

import React from "react";

class Signin extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      signInEmail: "",
      signInPassword: ""
    };
  }

  onEmailChange = event => {
    this.setState({ signInEmail: event.target.value });
  };
  onPasswordChange = event => {
    this.setState({ signInPassword: event.target.value });
  };
  onSubmitSignIn = () => {
    console.log(this.state);
    this.y;
  };

  render() {
    return (
      <article className="br4 ba  b--black-10 mv4 w-100 w-50-m w-25-l mw6 shadow-5 center">
        <main className="pa4 white-80">
          <form className="measure ">
            <fieldset id="sign_up" className="ba b--transparent ph0 mh0">
              <legend className="f4 fw6 ph0 mh0">Sign In</legend>

              <div className="mt3">
                <label className="db fw6 lh-copy f6">Email</label>
                <input
                  className="pa2 input-reset ba bg-transparent hover-bg-black hover-white w-100"
                  type="email"
                  name="email-address"
                  id="email-address"
                  onChange={this.onEmailChange}
                />
              </div>
              <div className="mv3">
                <label className="db fw6 lh-copy f6" for="password">
                  Password
                </label>
                <input
                  className="b pa2 input-reset ba bg-transparent hover-bg-black hover-white w-100"
                  type="password"
                  name="password"
                  id="password"
                  onChange={this.onPasswordChange}
                />
              </div>
            </fieldset>
            <div className="">
              <input
                className="b ph3 pv2 input-reset ba white-80 b--black bg-transparent grow pointer f6 dib"
                type="submit"
                value="Sign in"
                id="clicking"
                onClick={this.onSubmitSignIn}
                // onClick={this.props.y}
              />
            </div>
            <div className="lh-copy mt3">
              <a
                onClick={this.props.reg}
                type="submit"
                className="b ph3 pv2 input-reset ba white-80 b--black bg-transparent grow pointer f6 dib"
                value="Register"
              >
                Register
              </a>
            </div>
          </form>
        </main>
      </article>
    );
  }
}

export default Signin;

我真正希望看到的是,每当我在登录页面(前端部分)输入电子邮件和密码然后单击提交按钮时,我应该在控制台上看到电子邮件和密码并得到通过在提交按钮上调用 onClick 事件,登录主 page.technically,onSubmitSignIny 属性(登录)应该被执行。

但我既无法在控制台上看到密码和电子邮件,也无法登录并进一步操作。我应该如何通过一次简单的点击同时执行 onSubmitSignIn 和 Y?

当您提交表单时,您的浏览器会刷新,因为这是默认行为。

在提交事件上使用 preventDefault 来阻止这种情况发生。

onSubmitSignIn = (event) => {
  event.preventDefault();
  console.log(this.state);
  this.props.y();
};

我猜你在做

时会得到 undefined
console.log(this.state);

onSubmitSignIn里面,这是因为你没有bindthis

因此,在您的构造函数中添加以下内容:

  constructor(props) {
    super(props);
    this.state = {
      signInEmail: "",
      signInPassword: ""
    };
    this.onSubmitSignIn = this.onSubmitSignIn.bind(this);
  }

还要考虑到您的按钮是一个表单提交器,因此它会触发一个事件来提交表单,然后刷新页面。所以你还必须在 onSubmitSignIn

中添加以下内容
  onSubmitSignIn = (e) => {
    e.preventDefault();  // this will stop the propagation of the event.
    console.log(this.state); // this will log your state.
    this.props.y(); // this will call your y function from the parent.
  }; 

我添加了这些行,它执行了两个函数:

onSubmitSignIn = (event) => {
  event.preventDefault();
  console.log(this.state);
  this.props.y()
}

我不是写了event.preventDefault();我将无法看到日志。如果我没有在 y 之后加上括号(作为组件 Signin 的 属性),我就无法从父文件中调用它。

非常感谢大家。