У меня есть простая форма, которая состоит из поля электронной почты и поля пароля, как показано ниже
<Form noValidate validated={validated} onSubmit={this.handleSubmit}>
<Form.Group controlId="formEmail">
<Form.Label>Email address</Form.Label>
<Form.Control type="email" onChange={this.emailValidator} placeholder="Enter email" required />
</Form.Group>
<Form.Group controlId="formPassword">
<Form.Label>Password</Form.Label>
<Form.Control type="password"placeholder="Password" required />
</Form.Group>
<Button type="submit" size="lg" variant="light">
Login
</Button>
</Form>
Я хочу включить проверку формы начальной загрузки в поле электронной почты, когда пользователь начинает вводить адрес электронной почты и валидациюв поле пароля, когда нажата кнопка отправки.
Мой подход был следующим:
handleSubmit = event => {
const { loggingUser } = this.props;
const form = event.currentTarget;
event.preventDefault();
if (form.checkValidity() === false) {
event.preventDefault();
event.stopPropagation();
} else {
const loggingData = {
"eMail": event.target.formEmail.value,
"password": event.target.formPassword.value,
}
loggingUser(loggingData);
}
this.setState({
validated: true
})
};
emailValidator = event =>{
const form = event.currentTarget;
if (form.checkValidity() === false) {
event.preventDefault();
event.stopPropagation();
}
this.setState({
validated: true
})
}
Но когда я начинаю вводить в поле адреса электронной почты, обе проверки запускаются и показывают красныйграницы. Как я могу запустить проверку начальной загрузки для адреса электронной почты только тогда, когда пользователь начинает вводить адрес электронной почты.