我有一个包含2个FromGroups(用户和地址)的表单
我收到以下错误:
core.es5.js:1084 ERROR Error: Uncaught (in promise): Error: Cannot find control with name: 'street'
Run Code Online (Sandbox Code Playgroud)
当我使用这个课程
export class FormBuilderComp {
addUserFrom: FormGroup;
constructor( @Inject(FormBuilder) fb: FormBuilder) {
this.addUserFrom = fb.group({
userGroup: fb.group({
name: ['', Validators.required],
email: ['', Validators.required],
phone: ['', Validators.required]
}),
addressGroup: fb.group({
street: ['', Validators.required],
suite: ['', Validators.required],
city: ['', Validators.required],
zipCode: ['', Validators.required]
})
});
}
}
Run Code Online (Sandbox Code Playgroud)
...但是,如果我取出其中一个嵌套的FormGroups
export class FormBuilderComp {
addUserFrom: FormGroup;
constructor( @Inject(FormBuilder) fb: FormBuilder) {
this.addUserFrom = fb.group({
userGroup: fb.group({
name: ['', Validators.required],
email: ['', Validators.required],
phone: ['', Validators.required]
}),
street: ['', Validators.required],
suite: ['', Validators.required],
city: ['', Validators.required],
zipCode: ['', Validators.required]
});
}
}
Run Code Online (Sandbox Code Playgroud)
错误消失了.
是否有一些关于没有多个嵌套FromGroup的规则?
这是html,如果相关的话
<form [formGroup]="addUserFrom">
<fieldset formGroupName="userGroup">
<legend>User</legend>
<div class="form-group">
<label for="name">Name</label>
<input
type="text"
class="form-control"
id="name"
formControlName="name">
</div>
<div class="form-group">
<label for="email">Email</label>
<input
type="text"
class="form-control"
id="email"
formControlName="email">
</div>
<div class="form-group">
<label for="phone">Phone</label>
<input
type="text"
class="form-control"
id="phone"
formControlName="phone">
</div>
</fieldset>
<fieldset fromGroupName="addressGroup">
<legend>Address</legend>
<div class="form-group">
<label for="street">Street</label>
<input
type="text"
class="form-control"
id="street"
formControlName="street">
</div>
<div class="form-group">
<label for="suite">Suite</label>
<input
type="text"
class="form-control"
id="suite"
formControlName="suite">
</div>
<div class="form-group">
<label for="city">City</label>
<input
type="text"
class="form-control"
id="city"
formControlName="city">
</div>
<div class="form-group">
<label for="zipCode">Zip Code</label>
<input
type="text"
class="form-control"
id="zipCode"
formControlName="zipCode">
</div>
</fieldset>
<button>Submit</button>
</form>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9074 次 |
| 最近记录: |