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

Angular 2 Reactive Forms -如何显示与输入元素不同的FormArray控件

在Angular 2中,Reactive Forms提供了一种基于响应式编程模型的方式来处理表单。FormArray是Reactive Forms中的一个重要概念,它允许你创建和管理一个动态的表单控件数组。有时候,你可能需要显示与输入元素不同的FormArray控件,例如,你可能想要在一个列表中显示多个复选框或单选按钮,而不是单个输入框。

基础概念

FormArray 是一个可以包含多个表单控件的数组。它可以动态地添加或删除控件,非常适合用于创建复杂的表单,其中某些部分可能需要根据用户的输入或其他条件动态变化。

相关优势

  1. 动态性:FormArray允许你根据需要动态地添加或移除表单控件。
  2. 结构化:通过将相关的表单控件组织在一起,FormArray有助于保持代码的结构化和可维护性。
  3. 易于验证:Reactive Forms提供了强大的验证机制,可以轻松地对FormArray中的每个控件进行验证。

类型与应用场景

  • 复选框列表:当用户需要从多个选项中选择多个时。
  • 单选按钮组:当用户需要从多个选项中选择一个时。
  • 动态字段:例如,根据用户的选择动态添加或删除地址字段。

示例代码

以下是一个如何在Angular 2中使用FormArray来显示与输入元素不同的控件的示例:

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

@Component({
  selector: 'app-dynamic-form',
  template: `
    <form [formGroup]="form">
      <div formArrayName="items">
        <div *ngFor="let item of items.controls; let i = index" [formGroupName]="i">
          <input type="text" formControlName="name" placeholder="Item name">
          <button type="button" (click)="removeItem(i)">Remove</button>
        </div>
      </div>
      <button type="button" (click)="addItem()">Add Item</button>
    </form>
  `
})
export class DynamicFormComponent {
  form: FormGroup;

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

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

  addItem() {
    const itemGroup = this.fb.group({
      name: ['', Validators.required]
    });
    this.items.push(itemGroup);
  }

  removeItem(index: number) {
    this.items.removeAt(index);
  }
}

遇到的问题及解决方法

问题:FormArray控件没有正确显示或更新。

原因

  • 可能是由于Angular的变更检测机制没有被触发。
  • 可能是在添加或删除控件时,没有正确地更新FormArray。

解决方法

  • 确保在组件类中正确地使用了FormBuilder来创建和管理FormArray。
  • 在模板中使用*ngFor来迭代FormArray的控件,并且确保为每个控件提供了唯一的formGroupName
  • 如果在添加或删除控件后视图没有更新,可以尝试手动触发变更检测,例如使用ChangeDetectorRef服务。
代码语言:txt
复制
import { ChangeDetectorRef } from '@angular/core';

// 在组件类中注入ChangeDetectorRef
constructor(private fb: FormBuilder, private cdr: ChangeDetectorRef) {}

addItem() {
  const itemGroup = this.fb.group({
    name: ['', Validators.required]
  });
  this.items.push(itemGroup);
  this.cdr.detectChanges(); // 手动触发变更检测
}

通过这种方式,你可以确保FormArray控件能够正确地显示和更新,从而为用户提供一个流畅的表单填写体验。

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

相关·内容

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

一、Overview angular 入坑记录的笔记第三篇,介绍 angular 中表单控件的相关概念,了解如何在 angular 中创建一个表单,以及如何针对表单控件进行数据校验。...四、Step by Step 4.1、表单简介 用来处理用户的输入,通过从视图中捕获用户的输入事件、验证用户输入的是否满足条件,从而创建出表单模型修改组件中的数据模型,达到获取用户输入数据的功能 模板驱动表单...响应式表单 建立表单 由组件隐式的创建表单控件实例 在组件类中进行显示的创建控件实例 表单验证 指令 函数 在表单数据发生变更时,模板驱动表单通过修改 ngModel 绑定的数据模型来完成数据更新,...4.2.3、数据的有效性验证 某些时候需要对于用户输入的信息做有效性验证,此时可以在控件上添加上原生的 HTML 表单验证器来设定验证条件,当表单控件的数据发生变化时,angular 会通过指令的方式对数据进行验证...对于模板驱动表单,同样是采用自定义指令的方式进行跨字段的交叉验证,与单个控件的验证不同,此时需要将指令添加到 form 标签上,然后使用模板引用变量来获取错误信息 import { Directive

18.9K20

Angular系列教程-第四节

1.表单 Angular 提供了两种不同的方法来通过表单处理用户输入:响应式表单和模板驱动表单。...两者都从视图中捕获用户输入事件、验证用户输入、创建表单模型、修改数据模型,并提供跟踪这些更改的途径 使用’@angular/forms’库中的FormGroup, FormControl,FormArray...它会控制那些带有 ngModel 指令和 name 属性的元素,监听他们的属性。...总结 响应式表单是动态的,模板驱动表单是固定的 2.响应式表单使用 注册ReactiveFormsModule 组件导入FormControl 模板中注册组件 控件的值(获取setvalue...结构型指令 — 通过添加和移除 DOM 元素改变 DOM 布局的指令,比如ngfor、ngif 属性型指令 — 改变元素、组件或其它指令的外观和行为的指令,比如ngstyle 6.属性型指令 6.1

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

    首先需要操作表单的模块引入这两个模块; import { FormsModule, ReactiveFormsModule } from '@angular/forms'; ---- 表单控件响应的几种状态...; 在Submit()函数内,在点击提交的时候对整个表单一一去判断,传统方式基本这样 每个控件输入的时候对应去触发对应的事件做校验,比如[ngModelChange]来处理双向绑定的值校验 ---- 数据驱动...(Reactive Form) 响应式表表单:原理是一开始就构建整个表单,表单的值通过特殊指令formControlName一一关联(类似ngModel); 相关名词: FormGroup: 用来追踪表单控件有效状态及值...FormArray()),FormGroup()内置多种校验方式 formControlName: 同步与FormGroup构建表单内相同字段的值!...// v4+ , 第一位的''代表这个元素初始化构建为空值,类似未输入状态 // 'UserName': ['', Validators.compose([Validators.minLength

    3.8K20

    Angular8稳定版修改概述

    但这是如何工作的? 基本上,Angular将使用polyfill构建其他文件,并且它们将注入nomodule 属性。...改进了模板的类型检查(V9)。 较小的捆绑尺寸(V9)(如果您错过了I / O 19,Vikram Subramanian显示了一个4.3 KB版本的应用程序)。 向后兼容性。...正如Igor Minar所解释的那样,Bazel已经在内部使用了很长时间,现在可供所有人使用。您可以参考Bazel文档,并了解如何将其与Angular一起使用。...如果要触发一个表单组中所有控件的验证,这个方法将是非常有用的。...中清除所有元素 以前要删除所有元素,formArray 我们必须循环删除第一个元素直到空: while(formArray.length){ formArray.removeAt(0); } 现在就不需要那样操作了

    4.5K20

    AngularDart4.0 指南- 表单 顶

    一路上你将学习如何: 用组件和模板构建一个Angular表单。 使用ngModel创建读取和写入输入控制值的双向数据绑定。 跟踪状态变化和表单控件的有效性。...p模板输入变量在每次迭代中是不同的power; 您使用插值语法显示其名称。 与ngModel的双向数据绑定 现在运行应用程序有点令人失望。 ? 你没有看到英雄数据,因为你还没有绑定到英雄。...你知道如何从早期的页面做到这一点。 显示数据教导属性绑定。 用户输入显示如何使用事件绑定监听DOM事件以及如何使用显示的值更新组件属性。 现在您需要同时显示,聆听和提取。...每个input元素都有一个ngControl指令,Angular表单需要用这个指令在表单上注册控件。 如果您现在运行应用程序并更改每个英雄model属性,表单可能会显示如下: ?...用于验证和表单元素更改跟踪的NgControl 指令。 输入控件(通过模板引用变量访问)的valid 属性,用于检查控件有效性以及显示/隐藏错误消息。

    17.5K30

    Angular6自定义表单控件方式集成Editormd

    :用来获取原生表单控件的值更新时通知Angular表单控件更新的函数(即,设置当控件接收到 change 事件后,调用的函数) registerOnTouched:用来获取通知用户正在交互的函数(即,设置当控件接收到...该函数会根据参数值,启用或禁用指定的 DOM 元素。 ?...明确来说,那些原生表单控件都有其对应的ControlValueAccessor,比如: - DefaultValueAccessor - 用于 text 和 textarea 类型的输入控件 - SelectControlValueAccessor...formControl指令的实现: // https://github.com/angular/angular/blob/master/packages/forms/src/directives/reactive_directives...4.x 自定义表单控件 【荐】深入Angular自定义表单控件 Angular集成Editor.md的Markdown编辑器,支持NgModel双向绑定

    5.2K20

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

    然后我将展示如何封装第三方组件作为 Angular 组件,以及如何使用输入输出机制实现组件间通信(译者注:Angular 组件间通信输入输出机制可参考官网文档),最后将展示如何使用 ControlValueAccessor...),你需要把更新的值传给这个回调函数,这样对应的 Angular 表单控件值也会更新(译者注:这一点可以参考 Angular 它自己写的 DefaultValueAccessor 的写法是如何把 input...下图是 Angular 表单控件 如何通过 ControlValueAccessor 来和原生表单控件交互的(译者注:formControl 和你写的或者 Angular 提供的 CustomControlValueAccessor...Angular 也为所有原生 DOM 表单元素创建了 Angular 表单控件(译者注:Angular 内置的 ControlValueAccessor): Accessor Form Element...交互式表单控件 上面的实现还不能让我们自定义的 slider 控件与父组件交互,所以还得使用输入/输出绑定来是实现组件间数据通信: export class NgxJquerySliderComponent

    3.8K20

    angular面试题及答案_angular面试

    ngOnInit : 在angular 第一次显示数据绑定和设置指令、组件的输入属性之后,初始化指令、组件 所以从angular的生命周期看,constructor是执行在先的 所以既然ngOnchanges...如何优化Angular 2应用程序来获得更好的性能? 1)考虑AOT编译。 2)确保应用程序已经经过了捆绑,uglify和tree shaking。...最小化组件类的代码 不易于单元测试 Reactive Forms (响应式表单) 的特点 比较灵活 适用于复杂的场景 简化了HTML模板的代码,把验证逻辑抽离到组件类中...方便的跟踪表单控件值的变化 易于单元测试 33....|Function|string 类型的选择器 不同点 ContentChild 用来从通过 Content Projection 方式 (ng-content) 设置的视图中获取匹配的元素

    11.3K120

    Angular 6.x 快速入门

    基础知识 ngIf 指令简介 该指令用于根据表达式的值,动态控制模板内容的显示与隐藏。它与 AngularJS 1.x 中的 ng-if 指令的功能是等价的。...组件,开发一个功能,即可以让用户动态控制技能信息的显示与隐藏。...1.x 中的表单 ) Reactive Forms - 响应式表单 本小节主要介绍模板驱动式的表单,接下来我们来演示如何通过表单来为我们的之前创建的 UserComponent 组件,增加让用户自定义技能的功能...router-outlet 指令 该指令用于告诉 Angular 在哪里加载组件,当 Angular 路由匹配到响应路径,并成功找到需要加载的组件时,它将动态创建对应的组件,并将其作为兄弟元素,插入到...router-outlet 元素中。

    14.1K20

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

    NgModel - 与[(ngModel)]形成元素的双向绑定 在开发数据输入表单时,通常都会显示数据属性,并在用户进行更改时更新该属性。 使用NgModel指令进行双向数据绑定使得这一切变得简单。...谁可以记住要设置哪个元素属性以及哪个元素事件发出用户更改? 如何从输入框中提取当前显示的文本,以便更新数据属性? 谁想每一次都看看?...Angular为所有基本的HTML表单元素提供值访问器,Forms指南展示了如何绑定到它们。...'none' : 'block'">Hide with style 隐藏一个元素与用NgIf去除一个元素是完全不同的。 当你隐藏一个元素时,该元素及其所有的后代仍然保留在DOM中。...模板引用变量警告说明 模板引用变量(#phone)与模板输入变量(let phone)不同,如您在*ngFor中可能看到的那样。 了解“结构指令”指南中的差异。 引用变量的范围是整个模板。

    30K20

    Klee:用 C++ 实现数据驱动开发

    而我们在实际项目的开发过程中发现,同一个功能,综合考虑前期开发、后期 bug 与 UI 还原等阶段的人力投入,使用 Web 技术栈 来实现前端页面,研发效率大约是 平台原生开发 的 2 到 3 倍。...开发者只需要用代码或其他方式描述各个界面元素与数据之间的关系,数据的流向、界面的维护工作将由框架自动处理,大大简化程序员需要关注的内容。...直到读了 Vue.js 的源码后,才理解了依赖关系是如何在运行时收集维护的。...---- 与 RxSwift 的对比 同为 Native 数据驱动开发框架,Klee 从设计思路上与主流的 RxSwift 等框架有所不同。...多输入源 由于 Klee 的依赖关系是由框架自动建立的,不需要开发者维护,在多输入源的情况代码仍然非常简洁。

    2.4K30

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

    表单控件:包含了具体的表单功能项 3. 表单域:容纳所有表单控件和提示信息 常用的表单元素,包括: 1. form: 定义供用户输入的表单。 2. fieldset: 定义域。...可设置type属性,从而具有不同功能。 6. textarea: 定义文本域(一个多行的输入控件),默认可通过鼠标拖动调整大小。 7. button: 定义一个按钮。...,默认为”get”(也可以是post) name:控件名称;value:input控件默认文本值;size:input控件在页面中的显示宽度...还有一些新增的type属性: 1. search:input会呈现为搜索框(与text类型的唯一区别在于当鼠标覆盖时尾部出现叉号可快速清除输入的内容)。...2. tel:编辑电话号码的控件,提交时换行符会自动从输入框中去掉。 3. url:编辑url的控件,提交时换行符与首位的空格都将自动去除。 4. email:可输入一个邮件地址。

    3.4K30

    Xamarin.Forms入门-使用 Xamarin.Forms 来创建跨平台的用户界面

    Xamarin.Forms 通过使用平台的原生控件来渲染用户界面,使用 Xamarin.Forms 的 App在外观上与平台完全一致。...Layout - 布局或者容器控件 Cell - 表格或者列表控件的子项目 常用控件: Xamarin.Forms 控件 描述 Label 只读的文本展示控件 Entry 单行的文本输入框 Button...按钮 Image 图片 ListView 列表控件 Xamarin.Forms有两种不同类型的容器控件: Managed Layout - 与CSS的盒模型类似,通过设定子控件的位置和大小来进行布局...Unmanaged Layouts - 与Managed Layout不同,开发人员需要直接设定子控件的位置和大小,常见的例子就是 AbsoluteLayout。...堆栈式布局的子元素会按照添加到容器中的顺序一个接一个被摆放,堆栈式布局有两个方向:竖直与水平方向。 下面的代码会把三个 Label 控件添加到 StackLayout 中去。

    13K70

    Reactive UI -- 反应式编程UI框架入门学习 (转载非原创)

    Reactive UI Reactive UI 是一种反应式编程的跨平台MVVM框架,支持Xamarin Forms、Xamarin.iOS、Xamarin.Android、Xamarin.Mac、Tizen...2.控件和后台属性的对应关系更为直观,提高代码的可阅读性。 当然也有一定的缺陷,会增加代码量,并且增加View和ViewModel的耦合性。...ReactiveCommand的定义与MVVMLight大同小异。 但是在ReactiveUI中,还有更简单方便的定义可通知的属性,使用标记[Reactive]。...作用相同,都是与_disks强关联并创//建副本集合,在操作数据的时候,不直接操作_disks或者Disks,而是对DisksSource或//DisksSource2进行操作,会自动的同步到_disk...DiskSource和DiskSource2与_disk建立强关联关系的两种方式  DisksSource = new();            DisksSource.ToObservableChangeSet

    2.3K20

    angular知识点梳理第二篇-基本语法

    文章目录 前文回顾 基本语法 常见指令 NgModel NgFor NgIf Ng-container 管道 前文回顾 前面已经写了关于angular项目的基本介绍和如何创建一个angular项目,这一篇主要梳理一些...在app.modules.ts中引入forms模块 // 核心模块 import { NgModule } from '@angular/core'; //引入forms模块实现数据的双向绑定 import...{ FormsModule } from '@angular/forms'; @NgModule({ declarations: [], // 配置当前模块运行所依赖的其他模块 imports...{{item.id}} 运行效果 NgIf NgIf指令是可以控制页面元素的显示与消失,这里和隐藏要区别开,他的效果和css中的display:none效果是一致的,和visibility...官方的话:为没有 DOM 元素的指令安排宿主 管道 管道其实就是具有一定功能的函数,主要是一些场景是对字符串什么的进行简单的转化,当然我们也可以自己使用自定义的函数进行数据的转换,只是angular给我们提供了一些初始化的功能函数管道详细列表

    2.6K30
    领券