gpt4 book ai didi

Angular 2 验证器未按预期工作

转载 作者:太空狗 更新时间:2023-10-29 17:27:04 26 4
gpt4 key购买 nike

我得到了这个验证器:

export const PasswordsEqualValidator = (): ValidatorFn => {

return (group: FormGroup): Observable<{[key: string]: boolean}> => {

const passwordCtrl: FormControl = <FormControl>group.controls.password;
const passwordAgainCtrl: FormControl = <FormControl>group.controls.passwordAgain;

const valid = passwordCtrl.value.password === passwordAgainCtrl.value.passwordAgain;

return Observable.of(valid ? null : {
passwordsEqual: true
});
};
};

以这种形式使用:

  public signupForm: FormGroup = this.fb.group({
email: ['', Validators.required],
passwords: this.fb.group({
password: ['', Validators.required],
passwordAgain: ['', Validators.required]
}, {validator: CustomValidators.passwordsEqual()})
});

使用它的部分模板:

<div formGroupName="passwords">
<div class="form-control" [ngClass]="{error: !signupForm.get('passwords').valid}">
<label class="label" for="password">Password</label>
<input class="input" id="password" formControlName="password" type="password">
</div>
<div class="form-control" [ngClass]="{error: !signupForm.get('passwords').valid}">
<label class="label" for="password-again">Password again</label>
<input class="input" id="password-again" formControlName="passwordAgain" type="password">
</div>
</div>

问题是即使密码匹配,它仍然显示错误。我看过许多不同的类似问题,但其中大部分都有些困惑和过时,所以我想编写一个更简洁的解决方案。

我猜只需要做一个小的调整,但我似乎无法弄明白。

最佳答案

试试这个,因为你需要比较 2 个值并且验证器不是异步验证器,你可以只返回 boolean 而不是 Observable

export const PasswordsEqualValidator = (): ValidatorFn => {

return (group: FormGroup): boolean => {

const passwordCtrl: FormControl = <FormControl>group.controls.password;
const passwordAgainCtrl: FormControl = <FormControl>group.controls.passwordAgain;

const valid = passwordCtrl.value === passwordAgainCtrl.value;

return valid ? null : {
passwordsEqual: true
};
};
};

顺便说一句,使用此方法进行最佳实践:

export const PasswordsEqualValidator = (): ValidatorFn => {

return (group: FormGroup): boolean => {

const passwordCtrl: FormControl = group.get('password');
const passwordAgainCtrl: FormControl = group.get('passwordAgain');

const valid = passwordCtrl.value === passwordAgainCtrl.value;

return valid ? null : {
passwordsEqual: true
};
};
};

此处演示:http://plnkr.co/edit/9PzGSIuBhvNz0fpJxTlS?p=preview

关于Angular 2 验证器未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43618005/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com