Nat*_*May 5 typescript angular2-forms angular
我找到了这个答案,该答案显示了如何将表单控件添加到父表单:
但我希望能够像这样将新的formGroups添加到页面的不同区域。
<form [formGroup]="myForm">
<!--... other inputs -->
<md-tab-group formGroupName="nutrition">
<md-tab formGroupName="calories">
<template md-stretch-tabs="always" md-tab-label>Calories</template>
<template md-tab-content>
<calories></calories> <!-- I want to add controll groups like this-->
</template>
</md-tab>
<md-tab formGroupName="carbs">
<template md-stretch-tabs="always" md-tab-label>Carbs</template>
<template md-tab-content>
<carbs></carbs>
</template>
</md-tab>
</md-tab-group>
</form>
Run Code Online (Sandbox Code Playgroud)
整个表单模型应如下所示:
{
name: '',
nutrition:{
calories: {
total: ''
// more
},
carbs: {
total: ''
// more
}
}
Run Code Online (Sandbox Code Playgroud)
我已经能够nutrition像这样添加formGroup:
<nutrition [parentForm]="myForm"></nutrition>
import { Component, OnInit, Input } from '@angular/core';
import { FormGroup, FormControl, FormBuilder, Validators } from '@angular/forms';
@Component({
selector: 'nutrition',
template: `
<div [formGroup]="parentForm"></div>
`
})
export class NutritionComponent implements OnInit {
@Input() parentForm: FormGroup;
nutritionGroup: FormGroup;
constructor(private _fb: FormBuilder) {
}
ngOnInit() {
this.nutritionGroup = new FormGroup({
blank: new FormControl('', Validators.required)
});
this.parentForm.addControl('nutrition', this.nutritionGroup);
}
}
Run Code Online (Sandbox Code Playgroud)
但我不知道如何像这样将nutrition表单组传递给caloriesformGroup:
<calories [parentControl]="nutrition"></calories>
import { Component, OnInit, Input } from '@angular/core';
import { FormGroup, FormBuilder, FormControl, Validators } from '@angular/forms';
@Component({
selector: 'calories',
template: ``
})
export class CaloriesComponent implements OnInit {
@Input() parentControl: FormGroup;
caloriesForm: FormGroup;
constructor(private _fb: FormBuilder) { }
ngOnInit(){
this.caloriesForm = new FormGroup({
blank: new FormControl('', Validators.required)
});
this.parentControl.addControl('calories', this.caloriesForm);
}
}
Run Code Online (Sandbox Code Playgroud)
能做到吗?
如果您(或任何人)仍然感兴趣,在将控件添加到您的 之后parentControl,您需要将其发送回父组件,以便它可以更新。
import { Output, EventEmitter } from '@angular/core';
@Output() onFormGroupChange: EventEmitter<FormGroup> = new EventEmitter<FormGroup>();
this.parentControl.addControl('calories', this.caloriesForm);
this.onFormGroupChange.emit(this.parentControl);
Run Code Online (Sandbox Code Playgroud)
在父 html 元素上,您需要将其重新分配回parentControl:
(onFormGroupChange)="setParentControl($event)"
以及你的 ts 上的方法
public setParentControl(formGroup: FormGroup) {
this.myForm = formGroup;
}
Run Code Online (Sandbox Code Playgroud)
然后,您将拥有 FormGroup 中的控件myForm并在您的父元素上执行任何您喜欢的操作:
console.log(this.myForm.controls['calories'])
尚未包含所有代码,但仅包含您需要的代码:)
| 归档时间: |
|
| 查看次数: |
6016 次 |
| 最近记录: |