在Angular中,可以使用响应式表单来根据其他两个输入验证输入。以下是一个示例,展示了如何实现这个功能:
首先,我们需要在组件的HTML模板中创建一个响应式表单,并定义两个输入字段:
然后,在组件的TypeScript代码中,我们需要创建一个FormGroup对象并定义其控件:
import { Component, OnInit } from '@angular/core';
import { FormBuilder, Validators, FormGroup } from '@angular/forms';
@Component({
selector: 'app-my-form',
templateUrl: './my-form.component.html',
styleUrls: ['./my-form.component.css']
})
export class MyFormComponent implements OnInit {
myForm: FormGroup;
constructor(private formBuilder: FormBuilder) { }
ngOnInit() {
this.myForm = this.formBuilder.group({
input1: ['', Validators.required],
input2: ['', Validators.required],
input3: ['', Validators.required]
});
this.myForm.get('input3').setValidators([
Validators.required,
this.customValidator.bind(this)
]);
}
customValidator(control) {
const input1 = this.myForm.get('input1').value;
const input2 = this.myForm.get('input2').value;
const input3 = control.value;
if (input1 === input2 && input2 !== input3) {
return null; // valid
} else {
return { invalid: true };
}
}
}
在上面的代码中,我们首先使用FormBuilder创建一个FormGroup对象,并为每个输入字段定义了Validators.required验证器。然后,我们为input3字段添加了一个自定义验证器customValidator。该验证器使用FormGroup的get方法获取input1和input2字段的值,并与input3进行比较,如果不满足条件,则返回一个invalid为true的错误对象。
最后,在模板中使用*ngIf指令来根据表单控件的状态显示错误消息。
这样,当input1和input2的值相等,但input3的值不同时,input3字段将被标记为无效,并显示错误消息。
希望这个示例能帮助到你!