- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试通过示例 (full example on stackblitz) 来描述问题
如果我尝试以带有子组件的简单“formControls”或“formGroups”的形式放置 react 形式的某些部分,则没有问题。 (参见上面关于 stackblitz 的示例)。 FormGroupDirective
按预期工作。
但是如果我尝试将 FormArray 放置在子组件中,我会遇到麻烦,因为:
<div [formGroupName]="i">
<!--
Error: formGroupName must be used
with a parent formGroup directive.
-->
<div>
Reactive-Form 是一种简单的形式:
ngOnInit () {
this.newForm = this.fb.group({
id: [{value: '4711', disabled: this.idReadOnly}, Validators.required],
chapter: this.fb.group({
name: ['Some Chapter', Validators.required]
}),
faq: this.fb.array(this.faqArray)
});
}
如上所述,id
没有问题和 chapter
,它们在自定义子组件中实现,例如:
<fe-input
[controlPath]="['id']"
placeholder="Child-FormControl ID"
></fe-input>
<my-form-group
[controlPath]="['chapter', 'name']"
placeholder="Child-FormGroup Chapter"
[required]="true"
>
</my-form-group>
在 stackblitz 上的应用程序中,您将看到工作部分“ID”和“章节”。
与 formArray
相同的方法:
<my-form-array
[controlPath]="['faq']"
placeholder="Child-FormArray FAQ"
[required]="true"
></my-form-array>
应该按我的想法工作,但部分 <div [formGroupName]="i">
仅在子组件内导致上面已经提到的错误:
Error: formGroupName must be used
with a parent formGroup directive.
如果我在原始文件中使用它(定义 react 形式的地方),它可以正常工作。
我很困惑,也许我只是忽略了一个简单的问题?有人能帮我吗?整个示例可在此处在线获取:( >> stackblitz )
更新 1:
我已经将@yurzui 的解决方案与
viewProviders: [{
provide: ControlContainer,
useExisting: FormGroupDirective
}]
并且错误“Error: formGroupName must be used..
”消失了。之后,我为formArray字段集成了自定义组件,它们无法获取控件值。我想我已经接近解决方案了。那是自定义组件:
import { Component, OnInit, Input } from '@angular/core';
import {
FormControl,
FormGroupDirective
} from '@angular/forms';
@Component({
selector: 'fe-input',
template: `
<mat-form-field>
<input
matInput
[placeholder]="placeholder"
[formControl]="control"
[required]="required"
/>
<mat-error>
This is a required field!
</mat-error>
</mat-form-field>
`,
styles: [
]
})
export class FormElementInputComponent implements OnInit {
// Values to be set:
@Input() controlPath: any;
@Input() placeholder: string;
@Input() controlValue: any;
@Input() required = false;
// That's the reuseable control
control: FormControl;
constructor(private fgd: FormGroupDirective) {}
ngOnInit() {
this.control = this.fgd.control.get(
this.controlPath
) as FormControl;
}
}
最后是 my-form-array
的模板部分:
template: `
<div fxLayout="column">
<div *ngFor="let c of control.controls; index as i">
<div [formGroupName]="i">
<fe-input
[controlPath]="q"
placeholder="Question"
[required]="required"
></fe-input>
<fe-input
[controlPath]="a"
placeholder="Answer"
[required]="required"
></fe-input>
<div>
</div>
</div>
`,
最佳答案
首先,您的 FormArray 是 FormControls 的 FormArray,它们获取对象的值,而不是 FormGroup 的 FormArray。创建表单时必须更改
this.newForm = this.fb.group({
id: [{value: '4711', disabled: this.idReadOnly}, Validators.required],
chapter: this.fb.group({
name: ['Some Chapter', Validators.required]
}),
faq: this.fb.array(this.faqArray.map(x=>this.fb.group({
q:x.q,
a:x.a
})))
});
其次,您可以使用“其他方式”来处理 FormGroup 的 FormArray,它不使用 [formGroupName="i"] else [formGroup]="control"。是的
<!--remove this that not work
<div *ngFor="let c of control.controls; index as i">
<div [formGroupName]="i">
....
<div>
</div>
-->
<!--use [formGroup] -->
<div *ngFor="let c of control.controls; index as i">
<div [formGroup]="c">
....
</div>
</div>
好吧,在 formGroup 中你需要你的 fe-input [controlPath]="'q'"和 [controlPath]="'a'"
我删除了表单组,因为它也是错误的,尝试使用 [formGroup] 并使用 viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]
你看到你的 forked stackblitz
更新 如果我们使用标记 formArray
<my-form-array
[controlPath]="['faq','a','q']"
placeholder="Child-FormArray FAQ"
[required]="true"
></my-form-array>
我们可以在 ngOnInit 中改变我们的 my-form-array
this.control = this.fgd.control.get(
this.controlPath[0]
) as FormArray;
和 .html
<div *ngFor="let c of control.controls; index as i">
<div [formGroup]="c">
<fe-input *ngFor="let fields of controlPath.slice(1)"
[controlPath]="fields"
placeholder="Question"
[required]="required"
></fe-input>
</div>
关于可重用子组件中的 Angular react 形式 : Problem with FormArrays: `formGroupName` must be used with a parent formGroup directive,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56842459/
我有一个从 API 返回的嵌套 JSON 响应,其结构与我需要如何在模板上显示它的方式不同,例如: @Component({ selector: 'reactive-form-example',
如标题所述,formGroupName 值更改不会更新表单。(点击按钮后,输入中显示的值保持不变) 这是一个plunker . @Component({ selector: 'my-app',
如何在子组件中使用 formGroupName?例如: 我有ParentFormComponent parentForm: FormGroup; constructor(private
在这个表单中,我必须访问 formControlName="last"的控件以显示它的错误。 invalid Submit 此代码引发了未定义的错误“控件”(粗体格式行)。控件可以通过
我面临以下错误: EXCEPTION: Uncaught (in promise): Error: Error in ./AccComponent class AccComponent - inlin
我创建了 form: FormGroup 变量,我在服务的构造函数中使用 FormArray localizationData: FormArray 定义了组: this.form = this.fo
我正在尝试通过示例 (full example on stackblitz) 来描述问题 如果我尝试以带有子组件的简单“formControls”或“formGroups”的形式放置 react 形式
我是一名优秀的程序员,十分优秀!