我有一个有多个formGroups的formArray。每个formGroup都在一个扩展面板内。现在,当我单击"Check what's missing"按钮时,表单验证运行,并显示无效的表单域的错误。但是如果mat-expansion panel是关闭的,你就看不到哪些字段是无效的。当我检查表单验证时,我希望打开带有无效formGroup的扩展面板,以便用户可以看到哪些表单域无效。我已经添加了代码供您参考:
<!-- 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>
发布于 2019-12-31 18:50:52
使用ViewChildren获取扩展pannels
import {MatExpansionPanel} from '@angular/material/expansion';
@ViewChildren(MatExpansionPanel) pannels:QueryList<MatExpansionPanel> 在提交时,你可以做一些类似的事情,记住,“个人”的索引是0,“工作”的索引是1……
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();
....
})
}注意:我不知道您是如何制作表单的,所以条件可能会改变,但我希望这能对您有所帮助
发布于 2020-01-01 03:40:59
请看看这是否对你有帮助:
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阶段。
https://stackoverflow.com/questions/59538339
复制相似问题