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的值也会被正确地保留下来。

相关内容

热门资讯

一分钟揭秘!!红龙扑克真假,红... 一分钟揭秘!!红龙扑克真假,红龙扑克其实真的有挂(详细辅助器教程)1、完成透视辅助安装,帮助玩家取得...
透视辅助!红龙扑克总是真的是有... 透视辅助!红龙扑克总是真的是有挂,红龙扑克都是是有挂(详细辅助教程)是一款可以让一直输的玩家,快速成...
透视辅助!wpK透明挂辅助挂,... 透视辅助!wpK透明挂辅助挂,wpk总结其实是有挂(详细ai辅助教程);1、ai辅助优化,发牌逻辑科...
透视辅助!aapoKer都是真... 透视辅助!aapoKer都是真的有挂,aapoker讲解本来有挂(详细辅助工具教程)透视辅助!aap...
wepoke辅助插件!wepo... 1、wepoke辅助插件!wepower有机器人吗,(wepoke好友房)好像有挂(详细有辅助挂教程...
黑科技辅助挂!wepoke存在... 黑科技辅助挂!wepoke存在外挂么,(wepoke辅助)本来有挂(详细透明挂教程),您好,wepo...
透视辅助!红龙扑克辅助教程,红... 透视辅助!红龙扑克辅助教程,红龙扑克竟然有挂(详细辅助器教程)运辅助工具,进入游戏界面。进入辅助器,...
透视辅助!微扑克切实存在有挂,... 透视辅助!微扑克切实存在有挂,微扑克脚本都是有挂(详细系统发牌规律教程)1、点击下载安装,插件透视分...
传递经验!红龙扑克电脑模拟器,... 传递经验!红龙扑克电脑模拟器,红龙扑克原来是真的有挂(详细辅助工具教程);是一款可以让一直输的玩家,...
透视辅助!微扑克ai辅助工具,... 透视辅助!微扑克ai辅助工具,(微扑克总结)都是真的是有挂(详细辅助机器人教程)1、快速入门:当你通...