Angular2 でフォームを作成し、メール アドレスが既に存在するかどうかを確認する次のメソッドを作成しました。これが私のコードです:
checkEmail(): void {
// FIRST PART
this.found = false;
// If user is not Premium...
if (!this.currentUser.isPremium) {
// ...and if user typed something in the input field, then apply validitor for email address
if (this.myForm.controls.email.value.length > 0) {
this.myForm.controls.email.setValidators([validateEmail()]);
this.myForm.controls.email.updateValueAndValidity();
// If user leaves the input field blank or empty the typed input, then apply validator for required
} else {
this.myForm.controls.email.setValidators([Validators.required]);
this.myForm.controls.email.updateValueAndValidity();
}
// If user is Premium...
} else if (this.currentUser.isPremium) {
// ...and if user typed something in the input field, then apply validitor for email address
if (this.myForm.controls.email.value.length > 0) {
this.myForm.controls.email.setValidators([validateEmail()]);
this.myForm.controls.email.updateValueAndValidity();
// If user leaves the input field blank or empty the typed input, then remove any validator
} else {
this.myForm.controls.email.setValidators(null);
this.myForm.controls.email.updateValueAndValidity();
}
}
// SECOND PART
// If the input field is valid then check if the email already exist on server...
if (this.myForm.controls.email.value.length > 0 && this.myForm.controls.email.valid) {
this.loadingIcon = true;
this.anagraficaService.getEmail(this.myForm.controls.email.value)
.then(response => {
let count = response.recordCount;
if (count > 0) {
this.found = true;
} else {
this.found = false;
}
this.loadingIcon = false;
})
.catch(error => {
this.found = false;
this.loadingIcon = false;
});
}
}
テンプレート ファイルで [送信] ボタンを有効にするために、次のようmyForm.valid
にfound
設定されているかどうかを確認しfalse
ます。
<button type="submit" class="ui primary button" (click)="onSubmit()" [disabled]="!myForm.valid || found">Submit</button>
ここで、電子メール アドレスが既に存在するかどうかを確認したいと思います。つまり、コードの 2 番目の部分を外部ファイル (カスタム バリデーター) に配置し、コードの最初の部分でのみ電子メール アドレスの有効性を確認します。このようなもの:
this.myForm.controls.email.setValidators([validateEmail(), checkEmailExists()]);
this.myForm.controls.email.updateValueAndValidity();
同じ検証に到達するためのより良いアイデアはありますか? この問題に関するベストプラクティスはありますか?
ありがとうございました。