假设我们有两个表单字段对,即password和confirmPassword字段对,我们将展示如何在Angular中分别验证这两个字段对。
首先,我们需要在组件中引入FormControl:
import { Component, OnInit } from '@angular/core'; import { FormControl, FormGroup, Validators } from '@angular/forms';
接下来,我们需要创建一个名为myForm的FormGroup,并在其中添加名为password和confirmPassword的FormControl,并为它们设置必填和最小长度(假设设置为6)验证:
ngOnInit() { this.myForm = new FormGroup({ password: new FormControl('', [Validators.required, Validators.minLength(6)]), confirmPassword: new FormControl('', [Validators.required, Validators.minLength(6)]) }); }
现在,我们需要编写一个名为confirmPasswordValidator的验证方法,该方法将检查密码和确认密码是否匹配:
confirmPasswordValidator(control: FormControl): {[s: string]: boolean} { if (!control.root || !control.root.value) { return null; }
const password = control.root.value.password; const confirmPassword = control.root.value.confirmPassword;
if (confirmPassword !== password) { return { confirmPassword: true }; }
return null; }
最后,我们需要将confirmPasswordValidator方法与confirmPassword字段对的验证器关联:
ngOnInit() { this.myForm = new FormGroup({ password: new FormControl('', [Validators.required, Validators.minLength(6)]), confirmPassword: new FormControl('', [Validators.required, Validators.minLength(6), this.confirmPasswordValidator.bind(this)]) }); }
现在,我们就可以在HTML模板中使用myForm来显示表单和错误消息了: