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

Angular 7表单-有条件地需要FormGroup

是指在Angular 7中使用表单时,根据条件动态创建FormGroup对象。

Angular是一种流行的前端开发框架,它提供了丰富的表单处理功能。在Angular中,表单是由FormGroup、FormControl和FormBuilder等类组成的。

FormGroup是一个表单组,它可以包含多个FormControl。FormControl代表表单中的一个控件,可以是输入框、复选框、下拉框等。FormBuilder是一个辅助类,用于简化表单的创建过程。

有时候,我们需要根据条件动态地创建FormGroup对象。例如,当某个条件满足时,我们需要显示一个表单组,否则隐藏它。在这种情况下,我们可以使用Angular的条件表达式来创建FormGroup。

下面是一个示例代码:

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

@Component({
  selector: 'app-form',
  template: `
    <form [formGroup]="formGroup">
      <div *ngIf="showGroup">
        <input formControlName="name" placeholder="Name">
        <input formControlName="email" placeholder="Email">
      </div>
      <button (click)="toggleGroup()">Toggle Group</button>
    </form>
  `,
})
export class FormComponent {
  formGroup: FormGroup;
  showGroup: boolean = true;

  constructor(private formBuilder: FormBuilder) {
    this.formGroup = this.formBuilder.group({
      name: ['', Validators.required],
      email: ['', [Validators.required, Validators.email]],
    });
  }

  toggleGroup() {
    this.showGroup = !this.showGroup;
  }
}

在上面的代码中,我们首先导入了FormGroup、FormBuilder和Validators等类。然后在组件的构造函数中使用FormBuilder创建了一个FormGroup对象,并定义了两个FormControl,分别是name和email。

在模板中,我们使用*ngIf指令根据showGroup变量的值来决定是否显示表单组。当点击Toggle Group按钮时,toggleGroup方法会切换showGroup的值,从而实现动态显示或隐藏表单组。

这样,我们就实现了根据条件动态创建FormGroup对象的功能。

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

以上是关于Angular 7表单-有条件地需要FormGroup的完善且全面的答案。

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

相关·内容

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

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

2.8K30

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

一、Overview angular 入坑记录的笔记第三篇,介绍 angular表单控件的相关概念,了解如何在 angular 中创建一个表单,以及如何针对表单控件进行数据校验。...4.2.3、数据的有效性验证 某些时候需要对于用户输入的信息做有效性验证,此时可以在控件上添加上原生的 HTML 表单验证器来设定验证条件,当表单控件的数据发生变化时,angular 会通过指令的方式对数据进行验证...当构建复杂表单时,可以在 FormGroup 中通过嵌套 FormGroup 使表单的结构更合理 import { Component, OnInit } from '@angular/core';...g directive direactives/hero-validate 在创建完成指令之后,我们需要将这个指令将该验证器添加到已经存在的验证器集合中,同时为了使这个指令可以与 angular 表单集成在一起...4.4.2、跨字段的交叉验证 有时候需要针对表单中的多个控件数据进行交叉验证,此时就需要针对整个 FormGroup 进行验证。

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

    首先需要操作表单的模块引入这两个模块; import { FormsModule, ReactiveFormsModule } from '@angular/forms'; ---- 表单控件响应的几种状态...(Reactive Form) 响应式表表单:原理是一开始就构建整个表单表单的值通过特殊指令formControlName一一关联(类似ngModel); 相关名词: FormGroup: 用来追踪表单控件有效状态及值...FormArray()),FormGroup()内置多种校验方式 formControlName: 同步与FormGroup构建表单内相同字段的值!.../core'; import { FormGroup, Validators, FormBuilder } from '@angular/forms'; // 引入表单的一些特性 import { Router...---- 嵌套表单 有些时候我们接口数据层次不可能只有一层,出现两层三层都有可能; 这时候需要我们构建一个嵌套表单。。。

    3.8K20

    Angular系列教程-第四节

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

    2.8K50

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

    作者|接灰的电子产品 原文|http://www.jianshu.com/p/925adede7c60 为什么要做响应式编程? 我给出的答案很简单:响应式编程可以让你把程序逻辑想的很清楚。...响应式表单中的 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

    (数据科学学习手札113)Python+Dash快速web应用开发——表单控件篇(下)

    我们在上一期教程中已经对常见的几种具有不同功能的表单控件进行了比较详细的介绍,而在正式的开发网页表单时,不仅仅是将表单控件排列摆放出来那么简单随意,我们往往需要为控件添置一些补充内容,从而更好引导用户使用它们...,或是扩充出更多功能,这在Dash中我们可以借助dash_bootstrap_components的力量: 2.1 利用Form()、FormGroup()更好组织表单 dash_bootstrap_components...中的Form()与FormGroup()被设计用于更快捷排布我们的表单控件,使用逻辑是先用FormGroup()组织好每一个表单控件,再将若干个FormGroup()形成的列表作为Form()的children...参数,只不过这里我们在同一个FormGroup()中为指定表单控件添置valid参数相反的两种预设的FormFeedback()内容部件,接着只需要写个回调关联控件自身即可: app2.py import...  除了前面介绍的利用dbc.FormText()等部件为对应的表单控件生成外部说明文字之外,dash_bootstrap_components还提供了基于InputGroup()的一系列部件,使得我们可以方便创建出与控件本身浑然一体的说明内容

    1.1K20

    炫酷!纯Python开发LOL英雄信息查询平台

    图1 2 Dash表单控件进阶 我们在上一期教程中已经对常见的几种具有不同功能的表单控件进行了比较详细的介绍,而在正式的开发网页表单时,不仅仅是将表单控件排列摆放出来那么简单随意,我们往往需要为控件添置一些补充内容...,从而更好引导用户使用它们,或是扩充出更多功能,这在Dash中我们可以借助dash_bootstrap_components的力量: 2.1 利用Form()、FormGroup()更好组织表单 dash_bootstrap_components...中的Form()与FormGroup()被设计用于更快捷排布我们的表单控件,使用逻辑是先用FormGroup()组织好每一个表单控件,再将若干个FormGroup()形成的列表作为Form()的children...参数,只不过这里我们在同一个FormGroup()中为指定表单控件添置valid参数相反的两种预设的FormFeedback()内容部件,接着只需要写个回调关联控件自身即可: ❝app2.py ❞ import...除了前面介绍的利用dbc.FormText()等部件为对应的表单控件生成外部说明文字之外,dash_bootstrap_components还提供了基于InputGroup()的一系列部件,使得我们可以方便创建出与控件本身浑然一体的说明内容

    1K20

    Angular17 使用 ngx-formly 动态表单

    ngx-formly 是 Angular 应用实现响应式的动态表单框架,不仅支持自动生成表单、易于上手的自定义字段扩展、自定义验证扩展、支持 Formly Schema 和 JSON Schema,还有开箱即用的内置表单主题...快速开始 创建 Angular 项目: 安装并执行 CLI 创建 Angular 项目 # 基于 Angular 17 版本演示 # 注意要将 Nodejs 版本切换至 18.13+ npm install...FormlyNgZorroAntdModule, ], ... }) export class WelcomeModule {} 第二步:在页面中添加 form 和 formly-form 组件: <form [formGroup...fields 的定义: export class WelcomeComponent { form = new FormGroup({}); model = {}; fields: FormlyFieldConfig...,如在系统中通常相同 key 的表单需要对应相同的 label 字段,如果在前期考虑不好的话容易造成后期维护的困难,这里就可以考虑通过自定义扩展在生成动态表单前自动匹配 label 字段。

    64010

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

    为了确保 Angular 能够提供良好的类型检查、快速侦测变更,Angular 官方团队一直在调整静态检查和动态构建的平台。...事实上,从 Angular 9 开始,新的 Angular 应用程序就默认启用 lvy。...为了支持使用 View Engine 函数库的应用程序向后兼容,Angular 官方团队开发了 ngcc 相容编译器,ngcc 是编译 View Engine 函数库的方法,可以让 Ivy 应用程序方便使用...向 FormArray 与 FormGroup 中引入 emitevent 选项。也是一项重大变化。 向 routerLinkActiveOptions 中引入更多微调控件。...在表单中,引入最小与最大值验证器。 新版本可导出 HTTP 状态码列表。 向 Angular 语言服务添加一项功能,允许用户直接访问使用模板文件的组件的实际位置。

    4.4K10
    领券