我使用的反应本地的,一个formik形式,烨验证和火力认证。不过,我不断收到这个错误,当我尝试登录:
的createUser错误:错误:电子邮件地址格式错误。]
这里是我的代码:火力地堡API:
export const signInUser = (email, password) => {
console.log('signInUser has been called')
firebase.auth().signInWithEmailAndPassword(email.trim(), password)
.catch((error) => console.log('signIn error: ', error));
if (email==""){
console.log('email empty')
}
if (password==""){
console.log('password empty')
}
if (email=="[email protected]"){
console.log('email not empty')
}
}
登录屏幕:
createUser(){
FirebaseAPI.createUser(this.state.email, this.state.password)
}
signIn(){
FirebaseAPI.signInUser(this.state.email, this.state.password)
}
形成:
<Formik
initialValues={{ email: '', password:'' }}
onSubmit={(values: FormValues, formikBag: FormikActions<FormValues>) =>
this.handleSubmit(values, formikBag)}
validationSchema= {yupObject().shape({
email: yupString()
.email("Inavlid email address")
.required("This field is required"),
password: yupString()
.min(8, "Password must be longer than 8 characters")
.required("This field is required")
})}
render={(formikBag: FormikProps<FormValues>) => this.renderForm(formikBag)}
/>
这是记录该值后的结果:
[09:39:16] signInUser has been called
[09:39:16] email empty
[09:39:16] password empty
[09:39:16] signIn error: [Error: The email address is badly formatted.]
记录实际值将给出任何结果,所以我选择了检查,如果字符串是空的,看来他们是。然而,当我删除formik形式和使用普通的输入字段没有确认,一切工作正常。
在使用它之前验证this.state.email
。请参阅this了类似的问题。