首页 文章

如何在按钮点击时显示验证消息?

提问于
浏览
0

你能告诉我如何在点击按钮时显示验证消息吗?这是我的代码https://stackblitz.com/edit/angular-ugdbvg?file=src/app/app.component.html

我想在用户按 submit 按钮时显示 required 错误消息 .

<form novalidate [formGroup]="searchForm" class="calform">
      <section class="col-sm-6 bg-white  pl-20 pr-20">

      <div class="form-group col-sm-4 pl-0 error">
          <label class="field-title mb-5">name<span class="color-red fontWt">&nbsp;*</span></label>
          <input type="text" placeholder="Enter name" formControlName="name">
          <p class="message" [hidden]="searchForm.get('name')">Required</p>
        </div>

        <div class="form-group col-sm-4 pl-0 error">
          <label class="field-title mb-5">last name <span class="color-red fontWt">&nbsp;*</span></label>
          <input type="text" placeholder="Enter last name" formControlName="lastName">
          <p class="message" [hidden]="searchForm.get('lastName')">Required</p>
        </div>
        <button (click)="submitHandler()">submit</button>
      </section>
    </form>

JS

this.searchForm = this.fb.group({
      name: ['', Validators.required],
          lastName: ['', Validators.required]

    });

3 回答

  • 0

    添加以下行以检查:

    <span class="error" *ngIf="!!searchForm.controls.name.errors.required && (!!searchForm.controls.name.dirty || !!searchForm.controls.name.touched)">
        Name is required.
    </span> 
    <span class="error" *ngIf="!!searchForm.controls.lastName.errors.required && (!!searchForm.controls.lastName.dirty || !!searchForm.controls.name.touched)">
        lastName is required.
    </span>
    

    在你的ts文件中:

    submitHandler() {
        if(this.searchForm.valid) {
            // Logic
        }
    }
    

    https://stackblitz.com/edit/angular-utvw23

  • 1

    你需要使用* ngIf . 更新了Stackblitz代码 . https://stackblitz.com/edit/angular-fzyrji

  • 0

    试试这样:

    使用 [hidden]*ngIf

    DEMO

    <div class="form-group col-sm-4 pl-0 error">
                <label class="field-title mb-5">name<span class="color-red fontWt">&nbsp;*</span></label> {{show}}
                <input type="text" placeholder="Enter name" formControlName="name"> {{searchForm.get('name').invalid}}
                <p class="message" [hidden]="!(show && searchForm.get('name').invalid)">Required</p>
            </div>
    
            <div class="form-group col-sm-4 pl-0 error">
                <label class="field-title mb-5">last name <span class="color-red fontWt">&nbsp;*</span></label>
                <input type="text" placeholder="Enter last name" formControlName="lastName">
                <p class="message" [hidden]="!(show && searchForm.get('lastName').invalid)">Required</p>
            </div>
    
            <button (click)="show = true ; submitHandler();">submit</button>
        </section>
    </form>
    

相关问题