gpt4 book ai didi

angularjs - Angular 2动态生成的表单组

转载 作者:太空狗 更新时间:2023-10-29 18:31:40 26 4
gpt4 key购买 nike

我正在尝试动态生成一个 FormBuilder 组,但我被生成的组对象卡住了。我有以下组件,用于单个 .html 输入字段。

import { Component, onInit } from '@angular/core';
import { FormBuilder, FormControl, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';

@Component({
selector: 'app-home',
templateUrl: './home.component.html',
styleUrls: ['./home.component.css']
})

export class HomeComponent implements OnInit {
job: any;

constructor(
public formBuilder: FormBuilder
) {
this.job = {
number: 'J001'
}
}

ngOnInit() {
const jobGroup: FormGroup = new FormGroup({});
for (const key in this.job) {
if (this.job.hasOwnProperty(key)) {
const control: FormControl = new FormControl(this.job[key], Validators.required);
jobGroup.addControl(this.job[key], control);
}
}

this.jobForm = this.formBuilder.group(jobGroup);
}
}

当应用程序加载时,我在控制台中收到以下错误。

Error: Error in ./HomeComponent class HomeComponent - inline template:12:50 caused by: Cannot find control with name: 'number'

home.component.html如下。

<form [formGroup]="jobForm" novalidate>
<div class="form-group">
<label class="control-label" for="number">Job Number</label>
<input type="text" class="form-control" formControlName="number" id="number">
</div>

<button class="btn btn-success btn-block">Save Record</button>
</form>

我希望这是我错过的显而易见的事情。

最佳答案

我怀疑你在这里有两个错误:

1) this.obj[key] 应该是key

2) 你不需要调用带有参数 FormGroupformBuilder.group

const jobGroup: FormGroup = new FormGroup({});
for (const key in this.job) {
if (this.job.hasOwnProperty(key)) {
const control: FormControl = new FormControl(this.job[key], Validators.required);
jobGroup.addControl(key, control); // instead of this.obj[key]
}
}

this.jobForm = jobGroup; // jibGroup is already formGroup

Plunker Example

关于angularjs - Angular 2动态生成的表单组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42622027/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com