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

是否有更好的方法将值推送到具有数组作为Angular中的值的表单控件

在Angular中,如果你想要将一个值推送到具有数组作为值的表单控件,你可以使用FormArray来管理这个数组。FormArray是Angular表单模块中的一个类,它允许你创建一个可以动态添加或删除表单控件的数组。

基础概念

  • FormArray: 是一个可以包含多个表单控件的数组,它是FormControl和FormGroup的兄弟类。
  • FormGroup: 是一个包含多个FormControl的容器,用于表示表单的一部分。
  • FormControl: 表示表单中的一个单独的控件。

相关优势

  • 动态添加或删除表单控件。
  • 易于管理和维护复杂表单。
  • 提供了丰富的API来操作表单控件。

类型

  • FormArray: 用于管理一组表单控件。
  • FormGroup: 用于管理一组相关的表单控件。
  • FormControl: 用于管理单个表单控件。

应用场景

  • 当你需要创建一个可以动态增减字段的表单时。
  • 当你需要管理一组相似的表单控件时。

示例代码

假设你有一个表单,其中有一个字段是一个数组,你想要动态地向这个数组添加新的值。

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

@Component({
  selector: 'app-dynamic-form',
  templateUrl: './dynamic-form.component.html',
  styleUrls: ['./dynamic-form.component.css']
})
export class DynamicFormComponent {
  dynamicForm: FormGroup;

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

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

  addItem(value: string) {
    const control = this.fb.control(value, Validators.required);
    this.items.push(control);
  }

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

在HTML模板中,你可以这样使用:

代码语言:txt
复制
<form [formGroup]="dynamicForm" (ngSubmit)="onSubmit()">
  <div formArrayName="items">
    <div *ngFor="let item of items.controls; let i = index" [formGroupName]="i">
      <input formControlName="item" placeholder="Item">
    </div>
  </div>
  <button type="button" (click)="addItem('New Item')">Add Item</button>
  <button type="submit">Submit</button>
</form>

遇到的问题及解决方法

如果你遇到了无法将值推送到FormArray的问题,可能的原因包括:

  • 未正确初始化FormArray: 确保你在组件构造函数中正确地初始化了FormArray。
  • 未正确引用FormArray: 确保你在组件类中正确地引用了FormArray。
  • 模板绑定错误: 检查你的HTML模板是否正确地使用了formArrayName和formGroupName指令。

解决方法:

  • 确保你已经在组件中创建了FormArray,并且已经将其添加到FormGroup中。
  • 在模板中使用正确的指令来绑定FormArray和FormControl。
  • 如果你在添加新项时遇到问题,确保你使用了FormBuilder来创建新的FormControl,并且已经将其推送到FormArray中。

通过上述方法,你应该能够有效地将值推送到Angular表单中的数组控件。

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

相关·内容

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

类的实例对应于一个表单控件,在使用时,通过将控件的实例赋值给属性,后续则可以通过监听这个自定义的属性来跟踪表单控件的值和状态 import { Component, OnInit } from '@angular...通过使用 FormControl 控件的 value 属性,可以获得当前表单控件的一份数据值拷贝,通过 setValue 方法则可以更新表单的控件值 import { Component, OnInit...,然后将控件组中的每一个控件作为属性值添加到实例中 import { Component, OnInit } from '@angular/core'; // 引入 FormControl 和 FormGroup...使用 FormBuilder 构建的控件,每个控件名对应的值都是一个数组,第一个值为控件的默认值,第二项和第三项则是针对这个值设定的同步、异步验证方法 import { Component, OnInit...4.4、表单的自定义数据验证 4.4.1、自定义验证器 在很多的情况下,原生的验证规则无法满足我们的需要,此时需要创建自定义的验证器来实现 对于响应式表单,我们可以定义一个方法,对控件的数据进行校验,之后将方法作为参数添加到控件定义处即可

18.9K20

AngularDart4.0 指南- 表单 顶

一路上你将学习如何: 用组件和模板构建一个Angular表单。 使用ngModel创建读取和写入输入控制值的双向数据绑定。 跟踪状态变化和表单控件的有效性。...模板驱动的形式 您可以通过使用本页中描述的特定于表单的指令和技术在Angular模板语法中编写模板来构建表单。 您也可以使用响应式(或模型驱动)方法来构建表单。...跟踪控制状态 Angular表单控件可以告诉您用户是否触摸了该控件,值是否改变,或者该值是否失效。...touched和untouched指示控件是否被访问过。 valid反映了控制值的有效性。 样式控件 有效的控制属性是最有趣的,因为当一个控制值无效时,你想发送一个强烈的视觉信号。...删除#spy模板引用变量和使用它的诊断。 作为类绑定的替代方法,可以使用NgClass指令来设置控件的样式。

17.5K30
  • (转) 别再对 Angular 表单的 ControlValueAccessor 感到迷惑

    然后我将展示如何封装第三方组件作为 Angular 组件,以及如何使用输入输出机制实现组件间通信(译者注:Angular 组件间通信输入输出机制可参考官网文档),最后将展示如何使用 ControlValueAccessor...input,textarea 进行交互,并且很有可能需要自定义一个表单控件作为 Angular 组件而不是使用原生表单控件,而通常自定义表单控件会封装一个使用纯 JS 写的控件如 jQuery UI's...),你需要把更新的值传给这个回调函数,这样对应的 Angular 表单控件值也会更新(译者注:这一点可以参考 Angular 它自己写的 DefaultValueAccessor 的写法是如何把 input...控件每次更新值传给回调函数的,L52 和 L89);使用 registerOnTouched 方法来注册用户和控件交互时触发的回调(译者注:你可能会参考 L95)。...表单控件是如何数据同步的(译者注:作者贴的可能是 Angular v4.x 的代码,v5 有了点小小变动,但基本相似): export function setUpControl(control: FormControl

    3.8K20

    angularjs 表单验证

    二、表单中控制变量 屏蔽浏览器对表单的默认验证行为 在表单元素上添加novalidate标记即可,问题是我们怎么知道我们的表单有哪些字段是有效的,那些事非法或者无效的?...$parsers  $parsers的值是一个由函数组成的数组,当用户同控制器进行交互,并且ngModelController中的$setViewValue()方法被调用时,其中的函数在当用户同控制器进行交互...它和$parser流水线互不影响,用来对值进行格式化和转换,以便在绑定了这个值的控件中显示。  ...$dirty $dirty的值和$pristine相反,可以告诉我们用户是否和控件进行过交互。 $valid $valid值可以告诉我们当前的控件中是否有错误。...$invalid $invalid值可以告诉我们当前控件中是否存在至少一个错误,它的值和$valid相反。

    6.7K70

    Angular 6.x 表单快速入门

    比较灵活 适用于复杂的场景 简化了HTML模板的代码,把验证逻辑抽离到组件类中 手动创建 Form Model (同步) 方便的跟踪表单控件值的变化 易于动态添加表单控件 易于单元测试 本文主要介绍...目前 Angular 支持的内建 validators 如下: required - 设置表单控件值是非空的 email - 设置表单控件值的格式是 email min - 设置表单控件值的最小值 max...- 设置表单控件值的最大值 minlength - 设置表单控件值的最小长度 maxlength - 设置表单控件值的最大长度 pattern - 设置表单控件的值需匹配 pattern 对应的模式...在 Angular 中,我们可以通过 #userName="ngModel" 方式获取 ngModel 对象,然后通过 userName.valid 判断表单控件是否通过验证。...在 Angular 中表单控件有以下状态,我们可以通过 #userName="ngModel" 方式获取 ngModel 对象,进而获取控件的状态信息。

    4.6K20

    Angular: 最佳实践

    , status: Statuses.Read} ]; } 复制代码 所以,现在我们有一个基本组件(实际上就是一个容器),我们的组件可以从中派生以重用应用程序的全局值和方法。...所以,下面有几条规则需要考虑下: 有一个 API 调用的基础服务类。将简单的 HTTP 服务逻辑放在基类中,并从中派生 API 服务。...比如,你想在模版中为未正确填写表单控件添加 has-error 类(也就是说并非所有的校验都通过)。...如果我们有更多的表单控件,那么它会使得视图更加混乱,并且创建了很多重复的逻辑。...所以本文着重介绍 Angular 应用中的 TypeScript 的内容。 希望本文能够帮助你编写更干净的代码,帮你更好组织你的应用结构。

    2.9K40

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

    响应式表单中的 Rx Angular 的表单处理非常强大,有模版驱动的表单和响应式表单两类,两种表单各有千秋,在不同场合可以分别使用,甚至混合使用,但这里就不展开了。...Angular 中处理响应式表单只有 3 个步骤: 1、在组件的 HTML 模版中给要处理的控件加上 formControlName="blablabla" 2、form 标签中添加 [formGroup...比如下面代码中的 constructor(private fb: FormBuilder) { }),用 FormBuilder 构造表单控件数组并赋值给刚才的类型为 FormGroup 的成员变量。...这两个数据流其实是来自于两个控件的值的变化,而响应式表单获取值的变化是非常简单的就一行: 上面这行代码的意思是从表单的控件数组中取得 formControlName 为 age 的这个控件然后监听其值的变化...这个 else 可以携带一个模版的引用。比如下面例子中:如果用户登录成功显示用户名,否则显示登录链接。 另一个改进是 ngIf 中现在可以将评估表达式的结果赋值给一个变量,好处是什么呢?

    5.3K10

    深入讲解 ASP+ 验证

    我们研究了大量的数据输入表单,试图找到可以适用于尽可能多的表单的一种解决方案。我们发现,数据输入表单具有许多有趣的特性: 尽管错误信息或图标经常与输入元素相邻,但是它们几乎总是位于表的不同单元格中。...在大多数组件环境中,例如 Microsoft® ActiveX®,我们可能本来试图将所有验证控件的功能集成到一个控件中,处理不同模式下的不同属性。...Page 对象的属性和方法 属性或方法 说明 IsValid 属性 这是最有用的属性。该属性可以检查整个表单是否有效。通常在更新数据库之前进行该检查。...因此,如果要使用 CustomValidator,则不应提供没有相应服务器验证函数的客户机验证函数。 每个验证控件都可以确保将一个标准的客户端脚本块发送到页面中。...其中有一些确认是否有效的规则,开始,您作为一个开发人员可能会有些混淆,但是如果要生成对用户有实际帮助的错误信息,这些规则是必要的。

    5.3K10

    常用的表单元素有哪些_h5新增的表单元素属性

    可设置type属性,从而具有不同功能。 6. textarea: 定义文本域(一个多行的输入控件),默认可通过鼠标拖动调整大小。 7. button: 定义一个按钮。...,默认为”get”(也可以是post) name:控件名称;value:input控件默认文本值;size:input控件在页面中的显示宽度...相似的有formtarget特性。 5. readonly:一个boolean值,表明该input值是否能被用户修改,可用于信息展示等页面。...7. autocomplete:浏览器是否根据之前提交的输入情况对此input自动填值(即以option形式匹配之前的输入值),取值on或off,默认on。...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    3.4K30

    Angular系列教程-第四节

    1.表单 Angular 提供了两种不同的方法来通过表单处理用户输入:响应式表单和模板驱动表单。...两者都从视图中捕获用户输入事件、验证用户输入、创建表单模型、修改数据模型,并提供跟踪这些更改的途径 使用’@angular/forms’库中的FormGroup, FormControl,FormArray...等将数据和视图进行绑定(需要引入ReactiveFormsModule) 模板驱动的表单是我们实例化好一个类的数据之后,在html中使用 NgForm 指令后将数据和表单进行绑定,使用[(ngModel...)]来将表单的数据和和视图进行双向绑定,NgForm 指令为 form 增补了一些额外特性。....内置验证器 min 此验证器要求控件的值大于或等于指定的数字 max 此验证器要求控件的值小于等于指定的数字 required 此验证器要求控件具有非空值 requiredTrue 此验证器要求控件的值为真

    2.8K50

    最受欢迎的10大Angular技巧

    通过将全局对象作为令牌(token),你可以放心地使用、替换和测试代码。 ? https://twitter.com/marsibarsi/status/1274662852079517697?...s=20 控件值为 ReplaySubject 在某些情况下,你需要订阅控件 valueChanges 并获取其当前值。不要重新发明轮子,只需这样做即可: ?...管道 Angular 是非常强大的选项。它使我们能够遵循组件模板内部的声明性方法。...令我有些难过的是,一些 Angular 开发人员不喜欢创建自己的管道,可其实你几乎可以在任何数据转换的场景中创建管道。 这是适用于许多情况的通用管道示例: ?...s=20 小 结 Angular 是一个很大的主题,能说的东西还有很多。我有很多关于新技巧的想法,准备与社区分享我的最佳实践。

    2.1K40

    Angular 2 + 折腾记 :(2)初步认识angular2,不一样的开发模式

    ,ng2的开发模式就是类似一个树,从根节点无限发散 import { NgModule } from '@angular/core'; // 表单模块,比如你要在组件内用到一些表单元素或者数据绑定..., |是管道,支持多个管道,支持内置管道和自定义管道,:跟随是管道的参数,后续文档我写一个如何自定义管道的文章 []="":绑定组件内的值[单向,数据流向视图],指令,原生html控件的自身属性[value...b : 会判断item是否有a这个值,防止undefined或者null让视图渲染报错 ---- 最最最常用的内置指令 样式绑定(ngClass) [ngClass]或者[ngStyle]:可以传递一个对象...---- 总结 这一篇没有涉及到路由这些和表单这些; 准备拆成两个文章来说; 路由的配置及懒加载这些, 模板驱动的表单及响应式表单[嵌套表单响应等],回车键触发搜索等。。...发现文章有错误的,或者有更好讲解的,请留言指出,我会及时修正,谢谢! 其他的一丢丢废话:若是学会了ng2技术栈,其实你过程接触了Typescript,Rxjs,es6&7等

    6.2K20

    Angularjs基础(七)

    AngularJS表单     AngularJS表单时输入控件的集合 HTML控件     一下HTML input 元素被称为HTML 控件:         input 元素         ...formCtrl 函数设置了mater 对象的初始值,并定义了reset()方法。           reset() 方法设置了user 对象等于master对象。           ...novalidate 属性在应用中不是必须的,但是你需要在 AngularJS 表单中使用,用于重写标准的 HTML5 验证。...AngularJS输入验证     AngularJS表单和控件可以验证输入的数据。 输入验证     AngularJS表单和控件可以提供验证功能,并对用户输入的非法数据惊醒警告。...      angular.isString() 判断给定的对象是否为字符串,如果是返回true.

    2.1K70

    Angular 5.0.0发布!

    构建优化器是CLI中的一个工具,它基于我们对你Angular应用的理解,可以把构建后的包变得更小。 构建优化器有两个主要任务。...通过把状态从服务器传送到客户端,开发者就不用再发第二次HTTP请求了。状态转交的相关文档几周后会发布。 Angular Universal团队还把平台服务器Domino加到了平台服务器中。...保留空白 过去编译器会忠实地复现并在模板中包含制表符、换行符和空白。现在你可选择是否在组件和应用中包含空白了。 可以在每个组件的装饰器中指定这个配置,而当前的默认值为true。...Angular表单添加updateOn Blur/Submit 这样可以根据 blur或 submit来运行验证和更新值的逻辑了,不必再单纯依赖input事件。...表单对应用很重要,如果有服务端验证,或者验证或更新值会触发较慢的操作,你当然希望它少跑几次。现在你可以在控件层面控制验证和更新值的时机了,也可以在表单层面设置。

    4.4K40

    走进AngularJs(二) ng模板中常用指令的使用方式

    本篇我将搜罗模板中的常用指令一一测试,了解其使用方法,有点像背单词的感觉,会比较枯燥。...过滤器通常是伴随标记来使用的,将你model中的数据格式化为需要的格式。表单的控制功能主要涉及到数据验证以及表单控件的增强。   在这里有必要说明一下表达式的概念,毕竟我们模板中大部分使用的都是变量。...,数组中的每一项都会层叠起来生效;   3) 一个名值对应的map,其键值为类名,值为boolean类型,当值为true时,该类会被加在元素上。   ...框架会用display:block和display:none来控制元素的显隐。 三、表单控件功能相关的   对于常用的表单控件功能,ng也做了封装,方便灵活控制。   ...学英语有两种方法,一种是先做题,遇到不会的单词再查,另一种是先拿着单词本背。尽管专家好像更推荐前者,但如果你现在一窍不通,还是老老实实先背单词吧~

    3K20

    Angular的12个经典问题,看看你能答对几个?(文末附带Angular测试)

    Angular作为目前最为流行的前端框架,受到了前端开发者的普遍欢迎。...Angular应用程序具有路由器服务的单个实例,并且每当URL改变时,相应的路由就与路由配置数组进行匹配。...在成功匹配时,它会应用重定向,此时路由器会构建ActivatedRoute对象的树,同时包含路由器的当前状态。在重定向之前,路由器将通过运行保护(CanActivate)来检查是否允许新的状态。...它是如何在Angular 2中工作的? Angular 2不具有双向digest cycle,这是与Angular 1不同的。...这通常用在setter中,当类中的值被更改完成时。 可以通过模块的任何一个组件,使用订阅方法来实现事件发射的订阅。

    17.4K80

    AngularDart4.0 指南- 模板语法二 顶

    模板语句通常包含一个接收器,它响应事件执行一个动作,例如将HTML控件的值存储到模型中。 绑定通过一个名为$event的事件对象来传递关于该事件的信息,包括数据值。 事件对象的形状由目标事件决定。...Angular为所有基本的HTML表单元素提供值访问器,Forms指南展示了如何绑定到它们。...是否有理由回到扩展的形式? [(ngModel)]语法只能设置数据绑定属性。 如果您需要做更多或不同的事情,您可以编写扩展表单。...heroForm的值是什么? heroForm是一个Angular NgForm指令的引用,可以跟踪表单中每个控件的值和有效性。 原生元素没有form属性。...但是NgForm指令有,它解释了如果heroForm.form.valid无效并且将整个表单控件树传递给父组件的onSubmit方法,您可以禁用提交按钮。

    30K20
    领券