6

当我们继续在文本框中输入时,电子邮件验证被触发。我希望当用户关注文本框时触发此验证

下面是我的代码:

<input class="form-control" pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,3}$"
 name="Email" type="email" [(ngModel)]="model.Email" #Email="ngModel" required>

<div class="red" *ngIf="Email.errors && (Email.dirty || Email.touched)">
     <div [hidden]="!Email.errors.pattern">
         Please enter a valid email.
     </div>
</div>

请建议我如何实现这一目标。提前致谢。

4

3 回答 3

11

从版本 6+ 开始,可以通过updateOn属性设置表单字段验证。

使用模板驱动的表单:

<input [(ngModel)]="name" [ngModelOptions]="{updateOn: 'blur'}">

使用反应形式:

new FormControl('', {updateOn: 'blur'});

如果您设置了验证器:

new FormControl('', {validators: [Validators.required, Validators.email], updateOn: 'blur'})

来源:https ://angular.io/guide/form-validation#note-on-performance

于 2018-11-14T23:23:48.780 回答
0

这将在尚未发布的版本 5 中实现。

见:https ://github.com/angular/angular/issues/7113

同时:

<input class="form-control" formControlName="userName" placeholder="User Name" type="text" (blur)="checkUserExists()"/>
<div class="alert-danger" *ngIf="userName.invalid && userName.touched">
  <div *ngIf="userName.hasError('required')">User Name is required</div>
  <div *ngIf="userName.hasError('userExists')">{{userName.errors.userExists}}</div>
</div>

checkUserExists() {
    if (this.userName.value) {
      this.regServ.userNameExists(this.userName.value)
      .subscribe((exists) => {
        if (exists) {
          this.userName.setErrors({ userExists: `User Name "${this.userName.value}" already exists` });
        }
      });
    }
  }
于 2017-09-19T10:06:13.233 回答
0

如果您正在使用Angular,您可以通过这种方式调用

<input type="text" id="sometext" (focusout)="myFunction()">

否则,您可以使用

<input type="text" id="sometext" onfocusout="myFunction()">
于 2021-01-11T12:24:49.243 回答