在Angular中,如果要创建表单控件验证器(validator),有时需要依赖其他表单控件的值。例如,一个表单控件的值必须小于另一个表单控件的值。下面是一个示例:
在组件的FormGroup对象上定义两个FormControl对象,一个用于最小值,另一个用于最大值。创建另一个FormControl对象,用于存储值。在FormControl对象的validators数组中定义一个自定义验证器函数,该函数在验证过程中访问FormGroup对象中的其他FormControl对象,并根据需要执行验证逻辑。
示例代码如下:
import { Component } from '@angular/core';
import { FormGroup, FormControl, Validators } from '@angular/forms';
@Component({
selector: 'app-example',
template: `
Error: value must be between {{ form.get('min').value }} and {{ form.get('max').value }}
`
})
export class ExampleComponent {
form = new FormGroup({
min: new FormControl(0),
max: new FormControl(10),
value: new FormControl(5, [this.minmaxValidator])
});
minmaxValidator(control: FormControl) {
const min = control.parent.get('min').value;
const max = control.parent.get('max').value;
const value = control.value;
return value < min || value > max ? { minmax: true } : null;
}
}
在上面的示例中,我们定义了一个名为“minmaxValidator”的自定义验证器函数,该函数从FormGroup中检索最小值、最大值和当前值,并返回一个验证错误对象(如果不符合条件)或null(否则