首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当该面板的表单组无效时,如何打开mat-expansion panel?

当该面板的表单组无效时,如何打开mat-expansion panel?
EN

Stack Overflow用户
提问于 2019-12-31 08:34:22
回答 2查看 3.4K关注 0票数 2

我有一个有多个formGroupsformArray。每个formGroup都在一个扩展面板内。现在,当我单击"Check what's missing"按钮时,表单验证运行,并显示无效的表单域的错误。但是如果mat-expansion panel是关闭的,你就看不到哪些字段是无效的。当我检查表单验证时,我希望打开带有无效formGroup的扩展面板,以便用户可以看到哪些表单域无效。我已经添加了代码供您参考:

代码语言:javascript
复制
<!-- Personal Form inside Expansion Panel Personal -->
<mat-expansion-panel>
    <mat-expansion-panel-header>
        <mat-panel-title>
            Personal
        </mat-panel-title>
    </mat-expansion-panel-header>
    <app-personal-form [form]="form"></app-personal-form>
</mat-expansion-panel>

<!-- Work Form inside Expansion Panel Work -->
<mat-expansion-panel>
    <mat-expansion-panel-header>
        <mat-panel-title>
            Work
        </mat-panel-title>
    </mat-expansion-panel-header>
    <app-work-form [form]="form"></app-work-form>
</mat-expansion-panel>

<!-- Address Form inside Expansion Panel Work -->
<mat-expansion-panel>
    <mat-expansion-panel-header>
        <mat-panel-title>
            Address
        </mat-panel-title>
    </mat-expansion-panel-header>
    <app-address-form [form]="form"></app-address-form>
</mat-expansion-panel>

<div class="top-15" align="end">
    <button class="btn-success" mat-raised-button [disabled]="form.valid" (click)="form.showErrors()">Check what's missing</button> 
    <button class="btn-success" mat-raised-button [disabled]="!form.valid || !form.dirty" (click)="save()">Save</button>
</div>

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-12-31 18:50:52

使用ViewChildren获取扩展pannels

代码语言:javascript
复制
  import {MatExpansionPanel} from '@angular/material/expansion';

  @ViewChildren(MatExpansionPanel) pannels:QueryList<MatExpansionPanel>  

在提交时,你可以做一些类似的事情,记住,“个人”的索引是0,“工作”的索引是1……

代码语言:javascript
复制
submit()
{
  this.pannels.forEach((x,index)=>{
     if (index==0 && this.form.get('Personal').invalid)
        x.open();
     if (index==1 && this.form.get('Work').invalid)
        x.open();
   ....
   })
}

注意:我不知道您是如何制作表单的,所以条件可能会改变,但我希望这能对您有所帮助

票数 1
EN

Stack Overflow用户

发布于 2020-01-01 03:40:59

请看看这是否对你有帮助:

代码语言:javascript
复制
import { Component, Input,ApplicationRef} from '@angular/core';
import { FormGroup, FormBuilder, Validators } from '@angular/forms';

@Component({
  selector: 'my-app',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  myForm: FormGroup
  expanded = []
  errorPanles = []
  formSubmitted = false
  constructor(private fb: FormBuilder,private appRef: ApplicationRef) { }
  ngOnInit() {
    this.myForm = this.fb.group({
      personal: this.fb.group({
        fname: ['', [Validators.required]],
        lname: ['']
      }),
      work: this.fb.group({
        designation: ['', [Validators.required]],
        department: ['', [Validators.required]],
      })
    });
  }

  send(form) {
    this.formSubmitted = true
    this.expanded = []
    this.errorPanles = []
    this.appRef.tick();
    for (var key in form.controls) {
      if (form.controls[key].valid === false) {
        this.expanded.push(key)
      }
    }      
    this.errorPanles = this.expanded  
    if(this.errorPanles.length>0){
      // Form will not submit and material panel with error will open
    }else{
      // do whatever you want in case no error
    }
  }
}

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

我也在学习Angular阶段。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59538339

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档