问题描述: 在Angular 5中,使用Validator.pattern验证器与输入框的Input属性组合时,验证器似乎不起作用。
解决方法: 这个问题可能是由于正则表达式的模式不正确所导致的。下面是一个解决方法的示例:
import { Component } from '@angular/core';
import { FormGroup, FormBuilder, Validators } from '@angular/forms';
@Component({
selector: 'app-your-component',
templateUrl: './your-component.component.html',
styleUrls: ['./your-component.component.css']
})
export class YourComponent {
form: FormGroup;
constructor(private formBuilder: FormBuilder) {
this.form = this.formBuilder.group({
email: ['', [Validators.required, Validators.pattern(/^([a-zA-Z0-9_.+-]+)@([a-zA-Z0-9-]+)\.([a-zA-Z0-9-.]+)$/)]]
});
}
}
在上面的代码示例中,我们使用了FormGroup、FormBuilder和Validators类来创建一个表单组,并在创建表单组时应用了Validators.pattern验证器,用于验证电子邮件输入框的格式是否正确。
请注意,正则表达式模式是以斜杠开头和结尾的,例如:/^([a-zA-Z0-9_.+-]+)@([a-zA-Z0-9-]+).([a-zA-Z0-9-.]+)$/
最后,我们在模板中使用*ngIf指令来显示验证错误消息。当输入框的值无效且脏或触摸时,会显示错误消息。
希望这个解决方法能解决你的问题!