我创建了一个自定义验证器来检查用户填写的电子邮件地址。无论如何,电子邮件字段不是必需的,但如果我添加我的验证器,它也包括在内required。
这是我constructor的组件类中的表单:
this.myForm = fb.group({
'name': [''],
'surname': [''],
'username': ['', Validators.required],
'email': ['', validateEmail]
});
电子邮件字段不是必需的,但如果用户不填写它,则表单不会得到验证。同时,如果用户填写它,我希望应用电子邮件验证。
这是我的电子邮件验证器:
export function validateEmail(c: FormControl) {
var EMAIL_REGEXP = /^(|(([A-Za-z0-9]+_+)|([A-Za-z0-9]+\-+)|([A-Za-z0-9]+\.+)|([A-Za-z0-9]+\++))*[A-Za-z0-9]+@((\w+\-+)|(\w+\.))*\w{1,63}\.[a-zA-Z]{2,6})*$/i;
return EMAIL_REGEXP.test(c.value) ? null : {
validateEmail: {
valid: false
}
};
}
我可以编辑我的自定义验证器以接受空字符串,但我认为这不是解决我的问题的正确方法。
你有更好的主意吗?