Angular 11异步验证器在返回true响应时触发无尽的请求循环。
创始人
2024-10-15 10:00:58
0

在Angular 11中,当异步验证器返回true时触发无尽的请求循环的问题通常是由于验证器函数没有正确处理验证结果的情况下引起的。以下是一个包含代码示例的解决方案:

  1. 首先,确保你的异步验证器函数返回一个Observable对象,并使用RxJS操作符(如map、filter等)处理验证结果。
import { FormControl } from '@angular/forms';
import { Observable } from 'rxjs';
import { map } from 'rxjs/operators';

// 异步验证器函数
const myAsyncValidator = (control: FormControl): Observable => {
  return someAsyncValidation().pipe(
    map(result => {
      // 处理验证结果
      if (result === true) {
        // 验证通过
        return null;
      } else {
        // 验证失败
        return { asyncValidationFailed: true };
      }
    })
  );
};
  1. 在使用异步验证器的表单控件中,使用updateValueAndValidity方法来重新验证表单控件的状态。
import { FormGroup, FormBuilder } from '@angular/forms';

@Component({
  selector: 'app-my-form',
  template: `
    
` }) export class MyFormComponent implements OnInit { myForm: FormGroup; constructor(private fb: FormBuilder) {} ngOnInit() { this.myForm = this.fb.group({ myControl: ['', [], [myAsyncValidator]] }); this.myForm.get('myControl').valueChanges.subscribe(() => { // 当值发生变化时,重新验证表单控件 this.myForm.get('myControl').updateValueAndValidity(); }); } }

通过在值变化时手动调用updateValueAndValidity方法,可以确保在异步验证器返回true时,表单控件的状态会被正确更新,从而阻止无尽的请求循环。

相关内容

热门资讯

6分钟辅助!hhpoker是真... 6分钟辅助!hhpoker是真的假的,hhpoker真的有透视吗,演示教程(真是有挂)1、每一步都需...
第七分钟辅助!we poker... 第七分钟辅助!we poker插件,we poker免费辅助器,手筋教程(有挂方式)暗藏猫腻,小编详...
七分钟辅助!aa poker辅... 七分钟辅助!aa poker辅助包,pokemmo脚本辅助器下载,讲义教程(有挂秘籍)1、pokem...
第四分钟辅助!wepoker辅... 第四分钟辅助!wepoker辅助器安装包定制,aapoker透视脚本,大纲教程(有挂总结)所有人都在...
第四分钟辅助!wpk透视辅助靠... 第四分钟辅助!wpk透视辅助靠谱吗,wepoker透视苹果系统,诀窍教程(有挂猫腻);运wepoke...
七分钟辅助!aapoker透视... 七分钟辅助!aapoker透视脚本入口,wejoker开挂,学习教程(有挂教程)1、打开软件启动之后...
第四分钟辅助!淘宝买wepok... 第四分钟辅助!淘宝买wepoker透视有用吗,wpk俱乐部怎么作弊,积累教程(有挂规律)1、下载好淘...
6分钟辅助!we-poker软... 6分钟辅助!we-poker软件,购买的wpk辅助在哪里下载,积累教程(有挂技巧)购买的wpk辅助在...
第2分钟辅助!如何下载wepo... 第2分钟辅助!如何下载wepoker安装包,newpoker怎么安装脚本,教程书教程(今日头条)1、...
4分钟辅助!wepoker钻石... 4分钟辅助!wepoker钻石怎么看底牌,wepoker辅助器有哪些功能,法门教程(有挂详细)该软件...