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、快速入门:当你通过...
黑科技有挂!微扑克德州专用辅助... 黑科技有挂!微扑克德州专用辅助器(德扑ai机器人软件开发)一直是真的有挂(的确有挂)-哔哩哔哩1、玩...
黑科技讲解!gg扑克软件(德州... 黑科技讲解!gg扑克软件(德州ai辅助神器软件)固有存在有挂(证实有挂)-哔哩哔哩;无聊就玩这款德州...
黑科技神器!众合推扑克有辅助(... 黑科技神器!众合推扑克有辅助(aapoker发牌机制)往昔存在有挂(有挂解惑)-哔哩哔哩1、每一步都...
黑科技教程!cloud辅助(线... 黑科技教程!cloud辅助(线上wpk德州ai机器人)原本是有挂(确实有挂)-哔哩哔哩1、打开德州p...
黑科技实锤!wepoke黑科技... 黑科技实锤!wepoke黑科技设备(aapokerai辅助)往昔是真的有挂(真实有挂)-哔哩哔哩;人...
黑科技插件!德扑之星辅牌软件(... 黑科技插件!德扑之星辅牌软件(aapoker真的有猫腻吗)好像是真的有挂(有挂方针)-哔哩哔哩;一、...
黑科技新版!aapokerai... 黑科技新版!aapokerai辅助(德扑AI策略软件)果然存在有挂(有挂方式)-哔哩哔哩1、很好的工...
黑科技安卓版!gg扑克发牌是有... 黑科技安卓版!gg扑克发牌是有机制(微扑克透牌)往昔是真的有挂(竟然有挂)-哔哩哔哩1、在微扑克透牌...
黑科技挂!wpk有猫腻(wep... 1、黑科技挂!wpk有猫腻(wepokeai代打)素来有挂(详细教程)-哔哩哔哩;该软件可以轻松地帮...