如何在Angular2/4/5中实现自定义异步验证器

Ank*_*ngh 25 typescript angular

1.它甚至得到了Angular的支持吗?看到这个开放的问题

2.如果是的话,什么是错在下面的代码

export class someClass{

    myForm:ControlGroup;

    constructor(public http:Http, public formBuilder:FormBuilder)
       this.myForm = formBuilder.group({
            ImageId: ["", Validators.required, this.asynValidator]
    });

    asyncValidator(control: Control): {[key: string]: any} {

        return new Promise (resolve => {

          let headers = new Headers();
          headers.append('Content-Type', 'application/json');

          this.http.get('http://localhost/ImageIdValidate?id='+ control.value, {headers:headers})
                .map(res => res.json())
                .subscribe(data => {
                    console.log(data);
                    if(data != null) {
                        resolve({"duplicate": true})
                    }
                    else resolve(null);      
                })
            });
        });
      }
    }
Run Code Online (Sandbox Code Playgroud)

它甚至没有提出服务器请求.

Thi*_*ier 29

您需要在组件实例本身上绑定您的方法,如下所述:

this.myForm = formBuilder.group({
            ImageId: ["",    
               Validators.required, 
               this.asynValidator.bind(this)]
    });
Run Code Online (Sandbox Code Playgroud)

否则,您将无法使用http属性来执行请求.

本文还可以为您提供有关异步表单验证的一些提示(请参阅"异步验证"一节):

  • 事实上,这是JavaScript的工作方式.当您引用方法时,您将丢失其附加的对象.你可以使用bind方法强制这个... (7认同)