首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用FormArray Angular在formGroup中加载数据

Angular中的FormArray是一个用于处理动态表单控件的类。它允许我们在一个FormGroup中动态地添加和删除表单控件。

FormArray可以用于以下场景:

  1. 动态表单:当需要根据用户输入动态地添加或删除表单控件时,可以使用FormArray来管理这些控件。
  2. 重复表单控件:当需要重复使用相同的表单控件时,可以使用FormArray来管理这些控件的值和验证。
  3. 多选框组:当需要处理多个复选框的值时,可以使用FormArray来管理这些复选框的状态。

在Angular中,使用FormArray需要以下步骤:

  1. 在组件中创建一个FormArray实例,并将其添加到FormGroup中。
  2. 使用FormBuilder来创建表单控件,并将其添加到FormArray中。
  3. 在模板中使用*ngFor指令来循环显示FormArray中的表单控件。

以下是一个示例代码,演示了如何使用FormArray在FormGroup中加载数据:

代码语言:typescript
复制
import { Component } from '@angular/core';
import { FormBuilder, FormGroup, FormArray } from '@angular/forms';

@Component({
  selector: 'app-form',
  template: `
    <form [formGroup]="myForm" (ngSubmit)="onSubmit()">
      <div formArrayName="items">
        <div *ngFor="let item of items.controls; let i = index">
          <input [formControlName]="i" placeholder="Item {{ i + 1 }}">
        </div>
      </div>
      <button type="submit">Submit</button>
    </form>
  `,
})
export class FormComponent {
  myForm: FormGroup;

  constructor(private fb: FormBuilder) {
    this.myForm = this.fb.group({
      items: this.fb.array([]),
    });
  }

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

  onSubmit() {
    console.log(this.myForm.value);
  }

  loadData() {
    // 假设从服务器获取到的数据为 ['Apple', 'Banana', 'Orange']
    const data = ['Apple', 'Banana', 'Orange'];

    // 清空原有的表单控件
    while (this.items.length !== 0) {
      this.items.removeAt(0);
    }

    // 根据数据动态添加表单控件
    data.forEach((item) => {
      this.items.push(this.fb.control(item));
    });
  }
}

在上述示例中,我们创建了一个名为myForm的FormGroup,并在其中创建了一个名为items的FormArray。在模板中,我们使用*ngFor指令循环显示items中的表单控件,并使用formControlName绑定每个表单控件的值。

要加载数据,可以调用loadData方法,该方法会清空原有的表单控件,并根据从服务器获取到的数据动态地添加新的表单控件。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云云服务器(CVM):提供弹性计算能力,满足各类业务需求。产品介绍链接
  • 腾讯云云数据库MySQL版:提供高性能、可扩展的MySQL数据库服务。产品介绍链接
  • 腾讯云对象存储(COS):提供安全、稳定、低成本的云端存储服务。产品介绍链接
  • 腾讯云人工智能(AI):提供丰富的人工智能服务和解决方案,包括图像识别、语音识别、自然语言处理等。产品介绍链接
  • 腾讯云物联网(IoT):提供全面的物联网解决方案,帮助用户快速构建和管理物联网应用。产品介绍链接
  • 腾讯云移动开发(MSS):提供移动应用开发和运营的一站式解决方案,包括移动推送、移动分析、移动测试等。产品介绍链接
  • 腾讯云区块链(BCBaaS):提供安全、高效的区块链服务,帮助用户构建和管理区块链应用。产品介绍链接

请注意,以上链接仅供参考,具体产品选择应根据实际需求进行评估。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Angular系列教程-第四节

1.表单 Angular 提供了两种不同的方法来通过表单处理用户输入:响应式表单和模板驱动表单。...两者都从视图中捕获用户输入事件、验证用户输入、创建表单模型、修改数据模型,并提供跟踪这些更改的途径 使用’@angular/forms’库FormGroup, FormControl,FormArray...,FormBuilder 等类构建出的数据对象就是响应式的表单,响应式的表单,我们会在数据源里面进行各种操作,像添加校验等,html文件中使用 formGroup,formGroupName,formControlName...等将数据和视图进行绑定(需要引入ReactiveFormsModule) 模板驱动的表单是我们实例化好一个类的数据之后,html中使用 NgForm 指令后将数据和表单进行绑定,使用[(ngModel...使用 表单提交 更新部分内容(patchValue) 表单验证(导入Validators,设置字段属性) 表单状态(status) formarray(管理任意数量控件) 表单验证 同步验证器和异步验证器

2.8K50

Angular8稳定版修改概述

今天早些时候Angular团队发布了8.0.0稳定版。其实早在NgConf 2019大会上,演讲者就已经提及了从工具到差分加载的许多内容以及更多令人敬畏的功能。...Bazel可作为选择加入,预计将包含@angular/cli第9版。...懒加载的变动 新版本不推荐使用loadChildren:string 懒惰加载模块的语法。 8.0.0之前,懒加载的使用方法如下: loadChildren: '....清除所有元素 以前要删除所有元素,formArray 我们必须循环删除第一个元素直到空: while(formArray.length){ formArray.removeAt(0); } 现在就不需要那样操作了...弃的API 从 @angular/platform-browser删除了已弃的DOCUMENT 从@angular/platform-browser移除了DOCUMENT。

4.5K20
  • Angular 从入坑到挖坑 - 表单控件概览

    数据值和一些对于用户的行为约束(某个字段必须填啊、某个字段长度超过了长度限制啊)绑定到组件的模板,从而完成与用户的交互 4.2.1、模板驱动表单的双向数据绑定 根模块引入 FormsModule...4.3.2、通过 FomGroup 组合多个控件 一个表单不可能只有一个控件,通过组件构造 FormGroup 实例来完成对于多个表单控件的统一管理 使用 FormGroup 时,同样组件定义一个属性用来承载控件组实例...当构建复杂表单时,可以 FormGroup 通过嵌套 FormGroup 使表单的结构更合理 import { Component, OnInit } from '@angular/core';...类的方式来简化的完成表单的构建 FormBuilder 服务有三个方法:control、group 和 array,用于组件类中分别生成 FormControl、FormGroupFormArray...同模板驱动表单的数据有效性验证相同,响应式表单同样可以使用原生的表单验证器,设定规则时,需要将模板控件名对应的数据值的第二个参数改为验证的规则 响应式表单数据源来源于组件类,因此应该在组件类中直接把验证器函数添加到对应的

    18.9K20

    Angular 2 + 折腾记 :(7) 初步了解表单:模板驱动及数据驱动及脱坑要点

    前言 表单在整个系统的作用相当重要,这里主要扯下响应表单的实现方式。...模板驱动表单依赖FormsModule,数据驱动的表单依赖FormsModule,ReactiveFormsModule 一般做表单校验及操作推荐数据驱动的方式,好维护和理解。。...()函数内,点击提交的时候对整个表单一一去判断,传统方式基本这样 每个控件输入的时候对应去触发对应的事件做校验,比如[ngModelChange]来处理双向绑定的值校验 ---- 数据驱动(Reactive...=》 可以理解为获取且可以操作整个表单的数据 FormBuilder:表单数据构建工具[构建初始表单],简化构建代码(包括了new FormGroup(),new FormControl(),new...FormArray()),FormGroup()内置多种校验方式 formControlName: 同步与FormGroup构建表单内相同字段的值!

    3.8K20

    移除 View Engine 转用 Ivy,盘点Angular 12的重要更新

    对于语言服务,新版本仅在模板中提供 Angular 属性补全功能。 对于 compiler-cli,新版本为请求提供 context 选项以保障属性数据的类型安全。...这项功能可帮助用户针对各项请求 HTTP 客户端配置拦截器。 动画方面,当用户删除 root 视图时,现在可以正确删除其中的 DOM 元素。这是一项重大变化。...新版本,您可以通过 BrowserAnimationsModulewithConfig 禁用动画。 向 FormArrayFormGroup 引入 emitevent 选项。... HttpParams 上实现了 appendAll()方法。 表单,引入最小与最大值验证器。 新版本可导出 HTTP 状态码列表。...新增的诊断提示将建议您开启 strictTemplates,借此语言服务获得检索编译器选项诊断程序的方法。

    4.4K10

    Angular 表单2--响应式表单, 处理异步数据

    上一节我们定义了一个响应式表单,其中表单数据定义的时候就初始化好的,但是很多时候数据需要异步获取,比如 打开一个编辑页面,需要 请求HTTP拿到数据。...根据数据修改表单字段的值,最终体现在页面上。 我们改造上一节的例子,成为异步获取数据。...我们先创建service文件, 写一个loadUser方法,模拟HTTP请求 import { Injectable } from '@angular/core'; import { of } from...调用该方法 import { Component } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '...}); this.user$ = this.userService.loadUser().pipe( // tap 返回的还是 Observable 这里我们不订阅,我们模板中使用

    2.8K30

    Angular: 最佳实践

    类型规范 Typing 我们主要是 TypeScript 去编写 Angular(也许你只是 JavaScript 或者谷歌的 Dart 语言去写),Angular 被称为 TYPEScript 也是有原因的...我们知道一个路由对应一个 Angular 组件,但是我推荐你使用容器组件,它将处理数据(如果有数据需要传递的话)并将数据传递给另外一个组件,该组件将使用输入所包含的真实视图和 UI 逻辑。...服务 Services 服务是 Angular 业务逻辑存放和数据处理的方案。拥有提供数据访问、数据操作和其他可重用逻辑的结构良好的服务非常重要。...当然,国家不会每天都会发生变更,所以最好的做法就是拉取该数据并缓存,然后应用程序的生命周期内使用缓存的版本,而不是每次都去调用 API 请求该数据。...模版写 *ngIf=”someVariable === 1” 是可以的,其他很长的判断条件就不应该出现在模版

    2.8K40

    理论 | Angular 的响应式编程 -- 浅淡 Rx 的流式思维

     Rx--隐藏在Angular 2.x利剑 一文我们已经初步的了解了 Rx 和 Rx Angular 的应用。 今天我们一起通过一个具体的例子来理解响应式编程设计的思路。...响应式表单的 Rx Angular 的表单处理非常强大,有模版驱动的表单和响应式表单两类,两种表单各有千秋,不同场合可以分别使用,甚至混合使用,但这里就不展开了。...Angular 处理响应式表单只有 3 个步骤: 1、组件的 HTML 模版给要处理的控件加上 formControlName="blablabla" 2、form 标签添加 [formGroup...]="xxx" 指令,这个 xxx 就是你组件声明的 FormGroup 类型的成员变量:比如下面代码的 form: FormGroup; 3、组件的构造函数取得 FormBuilder 后(...比如下面代码的 constructor(private fb: FormBuilder) { }), FormBuilder 构造表单控件数组并赋值给刚才的类型为 FormGroup 的成员变量。

    5.3K10

    MongoDB Change Streams BigQuery复制数据

    一定的规模上为了分析而查询MongoDB是低效的; 2. 我们没有把所有数据放在MongoDB(例如分条计费信息)。 一定的规模上,作为服务供应商的数据管道价格昂贵。...构建管道 我们的第一个方法是Big Query为每个集合创建一个变更流,该集合是我们想要复制的,并从那个集合的所有变更流事件获取方案。这种办法很巧妙。...如果在一个记录添加一个新的字段,管道应该足够智能,以便在插入记录时修改Big Query表。 由于想要尽可能的Big Query获取数据,我们用了另外一个方法。...一个读取带有增量原始数据的源表并实现在一个新表查询的dbt cronjob(dbt,是一个命令行工具,只需编写select语句即可转换仓库数据;cronjob,顾名思义,是一种能够固定时间运行的...我们只具有BigQuery增加功能的变更流表作为分隔。

    4.1K20

    Angular5.0.0新特性

    Angular Universal是一个帮助开发者实现SSR的开源项目,通过服务端渲染 Angular应用程序,然后客户端引导启动程序并生成HTML,由此更好的支持那些对javascript不太友好的化境来提高应用程序性能...5.0版本Angular开发团队添加了ServerTransferStateModule(与之对应的BrowserTransferStateModule),这个模块允许你服务端生成模块信息并传输到客户端...这一点通过HTTP获取数据并展示时非常有用。通过服务端状态转移,客户端不需要在发送第二个HTTP数据请求,状态转移的API文档将在未来几周内发布。...4.国际化号码、日期和货币管道   Angular5已经建立了新的号码,日期和货币管道,增加了跨浏览器的标准化实现,消除国际化不同环境的差异。...8.HttpClient   4.3HttpClient模块被封装在@angular/common,新的HttpClient被封装在@angular/common/http,更新Http模块后

    1.7K10

    PandasPython可视化机器学习数据

    您必须了解您的数据才能从机器学习算法获得最佳结果。 更了解您的数据的最快方法是使用数据可视化。 在这篇文章,您将会发现如何使用PandasPython可视化您的机器学习数据。...单变量图 本节,我们将看看可以用来独立理解每个属性的技巧。 直方图 获取每个属性分布的一个快速方法是查看直方图。 直方图将数据分组为数据箱,并为您提供每个箱中观察数量的计数。...这是有用的,因为如果有高度相关的输入变量您的数据,一些机器学习算法如线性和逻辑回归性能可能较差。...您可以为数据的每对属性创建一个散点图。一起绘制所有这些散点图被称为散点图矩阵。 散点图对于发现变量之间的结构关系非常有用,例如是否可以一条线来总结两个变量之间的关系。...概要 在这篇文章,您发现了许多方法,可以使用Pandas更好地理解Python的机器学习数据

    2.8K60

    PandasPython可视化机器学习数据

    为了从机器学习算法获取最佳结果,你就必须要了解你的数据。 使用数据可视化可以更快的帮助你对数据有更深入的了解。...在这篇文章,您将会发现如何在Python中使用Pandas来可视化您的机器学习数据。 让我们开始吧。...单变量图 本节,我们可以独立的看待每一个特征。 直方图 想要快速的得到每个特征的分布情况,那就去绘制直方图。 直方图将数据分为很多列并为你提供每一列的数值。...这些图像看起来就像是把一幅抽象出来的直方图的每一列顶点一条平滑曲线链接起来一样。这就好比是肉眼直接处理直方图一样。...箱线图中和了每个特征的分布,中值(中间值)画了一条线,并且第25%和75%之间(中间的50%的数据)绘制了方框。

    6.1K50
    领券