在Angular11中,我们可以使用响应式表单进行验证和检查输入值的重复。有时,在表单中输入重复的值是不允许的。因此,我们需要使用响应式表单来检查重复值。
以下是一个示例,说明如何更改响应式表单,以检查输入值是否重复。
在组件的ts文件中,我们需要使用Validators类来编写自定义验证器,并在表单控件对象中调用该自定义验证器。
import { Component } from '@angular/core';
import { FormBuilder, FormGroup, Validators, ValidatorFn, FormControl } from '@angular/forms';
@Component({
selector: 'app-root',
templateUrl: './app.component.html'
})
export class AppComponent {
myForm: FormGroup;
constructor(private fb: FormBuilder) { }
ngOnInit() {
this.myForm = this.fb.group({
name: ['', [Validators.required]],
email: ['', [Validators.required, Validators.email]],
phone: ['', [Validators.required, Validators.pattern(/^01[0-9]{9}$/)]],
address: ['', [Validators.required]],
},
{validator: duplicateValidator('name')}
);
}
onSubmit() {
console.log(this.myForm.value);
}
}
// custom validator to check for duplicate name
export function duplicateValidator(field: string): ValidatorFn {
return (control: FormControl): {[key: string]: any} => {
const formGroup = control.parent;
if (formGroup) {
const nameControl = formGroup.get(field);
if (nameControl && nameControl.value === control.value) {
return {'duplicate': true};
}
}
return null;
};
}
在上述示例中,我们使用Validators.required,Validators.email和Validators.pattern等内置验证器来验证表单控件。同时,我们还添加了一个custom validator,即duplicateValidator来检查重复的名字进行验证。在这个验证器中,我们使用formGroup.get(field)方法来获取重复名称的表单控件,并在验证中与当前表单控件的值