Angular 10,带有数组的3级嵌套表单组。
创始人
2024-10-15 09:00:52
0

在Angular 10中,可以使用FormBuilderFormArray来创建带有数组的3级嵌套表单组。下面是一个示例代码:

首先,在组件类中导入所需的模块和类:

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

然后,在组件类中创建表单组并初始化:

export class MyComponent implements OnInit {
  myForm: FormGroup;

  constructor(private fb: FormBuilder) { }

  ngOnInit() {
    this.myForm = this.fb.group({
      // 第一级
      level1: this.fb.array([
        this.initLevel1()
      ])
    });
  }

  // 初始化第一级表单组
  initLevel1() {
    return this.fb.group({
      // 第二级
      level2: this.fb.array([
        this.initLevel2()
      ])
    });
  }

  // 初始化第二级表单组
  initLevel2() {
    return this.fb.group({
      // 第三级
      level3: this.fb.array([
        this.initLevel3()
      ])
    });
  }

  // 初始化第三级表单组
  initLevel3() {
    return this.fb.group({
      // 添加你需要的表单控件
      name: [''],
      age: ['']
    });
  }

  // 添加第一级表单组
  addLevel1() {
    const control = this.myForm.get('level1') as FormArray;
    control.push(this.initLevel1());
  }

  // 添加第二级表单组
  addLevel2(level1Index: number) {
    const control = (this.myForm.get('level1') as FormArray).at(level1Index).get('level2') as FormArray;
    control.push(this.initLevel2());
  }

  // 添加第三级表单组
  addLevel3(level1Index: number, level2Index: number) {
    const control = ((this.myForm.get('level1') as FormArray).at(level1Index).get('level2') as FormArray).at(level2Index).get('level3') as FormArray;
    control.push(this.initLevel3());
  }

  // 移除第一级表单组
  removeLevel1(level1Index: number) {
    const control = this.myForm.get('level1') as FormArray;
    control.removeAt(level1Index);
  }

  // 移除第二级表单组
  removeLevel2(level1Index: number, level2Index: number) {
    const control = (this.myForm.get('level1') as FormArray).at(level1Index).get('level2') as FormArray;
    control.removeAt(level2Index);
  }

  // 移除第三级表单组
  removeLevel3(level1Index: number, level2Index: number, level3Index: number) {
    const control = ((this.myForm.get('level1') as FormArray).at(level1Index).get('level2') as FormArray).at(level2Index).get('level3') as FormArray;
    control.removeAt(level3Index);
  }

  // 提交表单
  onSubmit() {
    console.log(this.myForm.value);
  }
}

在组件的HTML模板中,使用formGroupformArrayNameformGroupName指令来创建表单控件:

相关内容

热门资讯

透视模拟器!wepoker是不... 透视模拟器!wepoker是不是有人用挂(透视)竟然真的是有挂(详细辅助普及教程)1、玩家可以在软件...
科技分享!hhpoker作弊实... 1、科技分享!hhpoker作弊实战视频,wepoker怎么拿到好牌,解说技巧(有挂方法);详细教程...
透视ai!wepoker免费钻... 透视ai!wepoker免费钻石(透视)都是真的有挂(详细辅助系统教程);小薇(透视辅助)致您一封信...
一分钟教你!hhpoker是正... 一分钟教你!hhpoker是正品吗,wepoker有透视底牌吗,必赢方法(有挂透视)1、很好的工具软...
透视辅助!xpoker辅助怎么... 透视辅助!xpoker辅助怎么用(透视)好像是真的有挂(详细辅助教你教程)1、ai机器人多个强度级别...
解密关于!hhpoker作弊码... 这是一款非常优秀的wepokerplus万能挂 ia辅助检测软件,能够让你了解到wepokerplu...
2分钟细说!hhpoker怎么... 2分钟细说!hhpoker怎么防作弊,wejoker辅助软件视频,软件教程(有挂方法);玩家必备必赢...
透视游戏!wepoker钻石怎... 透视游戏!wepoker钻石怎么看底牌(透视)其实是真的有挂(详细辅助线上教程)1、机器人多个强度级...
透视工具!wepoker亲友圈... 透视工具!wepoker亲友圈有用吗(透视)原来是有挂(详细辅助德州论坛)1、金币登录送、破产送、升...
推荐一款!wepoker辅助器... 推荐一款!wepoker辅助器怎么弄,aapoker如何设置胜率,德州论坛(有挂软件)是一款可以让一...