Angular响应式表单无法在ngFor模板循环中使用formControlName设置值
创始人
2024-10-30 07:30:22
0

在Angular中,当使用响应式表单时,在ngFor模板循环中使用formControlName设置值可能会导致问题。这是因为ngFor会创建多个实例,这些实例共享相同的formControlName,这会导致冲突。

解决这个问题的一种方法是使用formGroupName。通过使用formGroupName,我们可以创建一个嵌套的FormGroup,并在ngFor循环中为每个实例设置唯一的formGroupName。

下面是一个示例代码,演示了如何解决这个问题:

在组件类中定义表单控件和表单组:

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

@Component({
  selector: 'app-my-component',
  templateUrl: './my-component.component.html',
  styleUrls: ['./my-component.component.css']
})
export class MyComponentComponent implements OnInit {
  myForm: FormGroup;

  constructor(private formBuilder: FormBuilder) { }

  ngOnInit() {
    this.myForm = this.formBuilder.group({
      items: this.formBuilder.array([])
    });
  }

  addItem() {
    const item = this.formBuilder.group({
      name: '',
      value: ''
    });

    this.items.push(item);
  }

  get items() {
    return this.myForm.get('items') as FormArray;
  }
}

在模板中使用formGroupName和formControlName设置值:

在上面的示例中,我们创建了一个items数组,每个数组元素都是一个嵌套的FormGroup。在ngFor循环中,我们使用[i]来设置每个实例的唯一formGroupName。

这样,我们就可以在ngFor循环中正确地使用formControlName设置值,而不会导致冲突。

相关内容

热门资讯

科技通报(德州之星安卓版)外挂... 科技通报(德州之星安卓版)外挂透明挂辅助软件(黑科技)辅助器(有挂方略)-哔哩哔哩;科技通报(德州之...
科普常识!吉祥填大坑插件,hh... 科普常识!吉祥填大坑插件,hhpoker软件可以玩,分享教程(有挂功能)运吉祥填大坑插件辅助工具,进...
玩家必看科普(WPK靠谱)外挂... 玩家必看科普(WPK靠谱)外挂透明挂辅助器(黑科技)透视挂靠谱(有挂猫腻)-哔哩哔哩是一款可以让一直...
大神推荐!樱花之盛能不能开挂,... 大神推荐!樱花之盛能不能开挂,wepoker究竟有透视,解密教程(有挂存在)暗藏猫腻,小编详细说明樱...
技术分享(AAPoKer数据)... 技术分享(AAPoKer数据)外挂透明挂辅助软件(黑科技)辅助透视是真的(有挂技巧)-哔哩哔哩;技术...
我来教大家!一起宁德吊蟹辅助,... 我来教大家!一起宁德吊蟹辅助,hhpoker买挂,大神讲解(有挂总结)1、一起宁德吊蟹辅助ai辅助优...
研究成果(智星德州菠萝功能)外... 研究成果(智星德州菠萝功能)外挂透明挂辅助挂(黑科技)有外挂(发现有挂)-哔哩哔哩;是一款可以让一直...
推荐十款!樱花之盛正版辅助器免... 推荐十款!樱花之盛正版辅助器免费,aapoker真的假的,科技教程(有挂细节)1、樱花之盛正版辅助器...
推荐攻略(悟空黑桃a微扑克)外... 推荐攻略(悟空黑桃a微扑克)外挂透明挂辅助工具(黑科技)软件透明挂是真的(有挂总结)-哔哩哔哩是一款...
一分钟教会你!闲聚app辅助软... 一分钟教会你!闲聚app辅助软件,德普之星的辅助工具介绍,详细教程(的确有挂)1、点击下载安装,闲聚...