Angular的FormArray导致另一个表单中的FormControl丢失
创始人
2024-10-24 03:01:02
0

若在Angular中使用FormArray导致另一个表单中的FormControl丢失,可能是由于表单的重新渲染导致FormControl被重置。可以使用以下方法解决这个问题:

  1. 确保在重新渲染表单之前,将FormControl的值保存在变量中。
  2. 使用setValue或patchValue方法将保存的值重新设置给FormControl。

以下是一个示例代码,演示如何解决该问题:

import { Component, OnInit } from '@angular/core';
import { FormBuilder, FormGroup, FormArray } from '@angular/forms';

@Component({
  selector: 'app-example',
  template: `
    
`, styleUrls: ['./example.component.css'] }) export class ExampleComponent implements OnInit { parentForm: FormGroup; constructor(private fb: FormBuilder) { } ngOnInit() { this.parentForm = this.fb.group({ childFormArray: this.fb.array([ this.createChildForm() ]) }); } createChildForm(): FormGroup { return this.fb.group({ childControl: '' }); } saveChildFormValues() { // 保存FormControl的值 const childFormValues = this.childFormArray.controls.map(control => control.value); // 重新渲染表单 this.parentForm = this.fb.group({ childFormArray: this.fb.array([ this.createChildForm(), this.createChildForm() ]) }); // 将保存的值重新设置给FormControl childFormValues.forEach((value, index) => { this.childFormArray.controls[index].setValue(value); }); } get childFormArray(): FormArray { return this.parentForm.get('childFormArray') as FormArray; } }

在这个示例中,我们首先在ngOnInit方法中创建了一个表单控件parentForm和一个FormArray childFormArray。然后,我们在模板中使用ngFor循环遍历childFormArray,创建多个子表单。

在saveChildFormValues方法中,我们首先保存了每个FormControl的值到childFormValues数组中。然后,我们重新渲染了表单,创建了新的childFormArray。最后,我们通过forEach循环将保存的值重新设置给新的FormControl。

这样,即使表单重新渲染,FormControl的值也会被正确地保留下来。

相关内容

热门资讯

透视玄学!黑侠破解wepoke... 透视玄学!黑侠破解wepoker,从来有挂(透视)详细教程(有挂规律)1、黑侠破解wepoker透视...
透视ai代打!wpk作弊最怕三... 透视ai代打!wpk作弊最怕三个东西,wpk是真的还是假的,实用技巧(本来是真的有挂);透视ai代打...
透视好友房!pokermast... 透视好友房!pokermaster修改器,约局吧德州透视,2025教程(有挂揭秘)亲,关键说明,约局...
透视透视!约局吧是否有挂,原本... 透视透视!约局吧是否有挂,原本是有挂(透视)透明挂教程(有挂揭秘);1、点击下载安装,约局吧是否有挂...
透视有挂!有哪些免费的wpk作... 透视有挂!有哪些免费的wpk作弊码,wpk是真的还是假的,解密教程(一直有挂)在进入有哪些免费的wp...
透视工具!pokemmo辅助器... 透视工具!pokemmo辅助器手机版下载,竞技联盟破解版最新版,总结教程(有挂黑科技)1、下载好po...
透视真的!wepoker私局代... 透视真的!wepoker私局代打,好像真的有挂(透视)2025新版(有挂辅助)小薇(透视辅助)致您一...
透视好友!wpk可以作弊吗,w... 透视好友!wpk可以作弊吗,wpk私人局有透视吗,详细教程(总是存在有挂)1、该软件可以轻松地帮助玩...
透视有挂!红龙poker辅助工... 透视有挂!红龙poker辅助工具,werplan怎么作弊,揭秘攻略(有挂技巧)红龙poker辅助工具...
透视ai!wpk辅助,总是真的... 透视ai!wpk辅助,总是真的有挂(透视)wepoke教程(有挂方法)一、wpk辅助软件透明挂的定义...