本文介绍了棱角材料步进器每次单击都会动态添加新的步进项的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我在项目中使用角形材料。我想在每次单击 addItem
按钮时添加额外的步进项目(垫子步进)。
I am using angular material in my project. I want to add extra stepper item(mat-step) on every click of addItem
button.
我创建了一个这里的矮子。
I created a plunker here. https://stackblitz.com/edit/angular-enmq1z?file=app%2Fstepper-overview-example.ts
有人可以帮我吗?
预先感谢。
推荐答案
我会使用以及
I would use FormArray
along with FormGroup
HTML:
<button mat-raised-button (click)="addItem()">
add item
</button>
<form [formGroup]="formGroup">
<mat-horizontal-stepper formArrayName="form">
<mat-step [formGroupName]="i" *ngFor="let customerGroup of formGroup.controls.form.controls; let i = index">
<ng-template matStepLabel>Step {{i + 1}}</ng-template>
<mat-form-field>
<input matInput placeholder="Address" formControlName="cont" required>
</mat-form-field>
<div>
<button mat-button matStepperPrevious>Back</button>
<button mat-button matStepperNext>Next</button>
</div>
</mat-step>
</mat-horizontal-stepper>
</form>
TS代码:
import {Component, OnInit} from '@angular/core';
import {FormBuilder, FormControl,FormGroup, Validators,FormArray} from '@angular/forms';
/**
* @title Stepper overview
*/
@Component({
selector: 'stepper-overview-example',
templateUrl: 'stepper-overview-example.html',
styleUrls: ['stepper-overview-example.css'],
})
export class StepperOverviewExample implements OnInit {
isLinear = false;
formGroup : FormGroup;
form: FormArray;
constructor(private _formBuilder: FormBuilder) {
}
ngOnInit() {
this.formGroup = this._formBuilder.group({
form : this._formBuilder.array([this.init()])
})
this.addItem();
}
init(){
return this._formBuilder.group({
cont :new FormControl('', [Validators.required]),
})
}
addItem(){
this.form = this.formGroup.get('form') as FormArray;
this.form.push(this.init());
}
}
这篇关于棱角材料步进器每次单击都会动态添加新的步进项的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!