原文

  https://www.jianshu.com/p/c772d143e1fc

大纲

  1、对表单的理解
  2、模板驱动表单(Template Driven Forms)
  3、响应式表单(Reactive Forms )
  4、响应式表单和模板驱动表单的区别和联系
  5、FormControl、FormGroup——angular基础的表单对象

对表单的理解

1、事实证明,表单最终可能是非常复杂的。原因如下:

  1.1、表单输入意味着需要在页面和服务器端同时修改这份数据;
  1.2、修改的内容通常要在页面的其他地方反映出来;
  1.3、用户的输入可能存在很多问题,所以需要验证输入的内容;
  1.4、用户界面需要清晰地显示出可能出现的预期结果和错误信息;
  1.5、字段之间的依赖可能存在复杂的业务逻辑;我们希望不依赖DOM选择器就能轻松测试表单。

2、值得庆幸的是,Angular已经给出了上述所有问题的解决方案。

  2.1、表单控件(FormControl)封装了表单中的输入,并提供了一些可供操纵的对象。
  2.2、验证器(validator)让我们能以自己喜欢的任何方式验证表单输入。
  2.3、观察者(observer)让我们能够监听表单的变化,并作出相应的回应。

模板驱动表单(Template Driven Forms)

  1、模板驱动(也叫模型驱动/Model Driven)表单是同步类型的表单。
  2、模版驱动的表单和 AngularJS 对于表单的处理类似,把一些指令(比如 ngModel )、数据值和行为约束(比如 require 、minlength 等等)绑定到模版中。总体来说,这种类型的表单通过绑定把很多工作交给了模版。
  3、进行模版驱动类型的表单处理的一个必要步骤就是建立数据的双向绑定,通过ngModel进行双向绑定

响应式表单(Reactive Forms )

  1、响应式表单(Reactive Forms )是异步类型的表单。
  2、响应式表单乍一看还是很像模板驱动型表单的,但响应式表单需要引入一个不同的模块: ReactiveFormsModule 而不是 FormsModule
  3、响应式表单区别于模板驱动型表单的的主要特点在于:是由组件类去创建、维护和跟踪表单的变化,而不是依赖模板。

响应式表单和模板驱动表单的区别和联系

  1、其实表单的创建都是表单的基础对象FormControl、FormGroup这两个基础表单对象的创建,不同点在于,模板驱动表单的创建是隐式的,即引入了FormsModule就自动在每个form对象创建了FormControl、FormGroup,只不过我们需要通过显示的命名name和牵引ngForm才可以调用对应的表单对象;而对于响应式表单,是显示的创建FormGroup和FormControl,无论是在每个form对象中添加FormGroup还是在每个表单控件添加FormControlName都是显示的创建表单对象并且获取对应表单的控制权限。
  2、[(ngModel)]并不能说是模板驱动型表单和响应式表单之间的区别,因为在响应式表单中我们也可以调用ngModel来让表单模型数据和数据模型数据关联起来(需要注意的是,使用ngModel,利用formControl创建的初始值是没有效果的会被ngModel覆盖),两个表单的本质区别在于:模板驱动表单的FormControl和FormGroup都是在模板上通过添加对应的name和ngForm来创建的,乃至其校验的方式也是在模板上添加对应的标签从而来添加校验,唯一与数据模型有管理的是通过ngModel和数据模型数据相关联。而对应的响应式表单也就是模型驱动表单的所有FormGroup和FormControl都需要在组件中创建添加控制权限,乃至校验规则也是需要在后台赋予的,和模板唯一关联的是需要通过显示的在模板中添加FormGroup和FormControlName来关联对应的表单和表单控件。
  3、响应式表单和模板驱动表单添加校验规则的方式不一样,因此它们的自定义校验指令的创建方式也是不同的,虽然最终都是要继承validator。
  4、响应式表单和模板驱动表单两者表单提交的方式是一样的
  5、不管是模板表单还是响应式表单,都存在两个模型,表单模型和数据模型,做到两个模型的格式相匹配可以让代码的可读性提高很多。
  总而言之:表单是关联数据、管理数据的工具,模板驱动表单是异步的,表单组件的创建和校验在于模板中;响应式表单是同步的,表单组件的创建和校验集中于组件之中。

FormControl、FormGroup——angular基础的表单对象

  1、FormControl和FormGroup是Angular中两个最基础的表单对象。
  2、FormControl代表单一的输入字段,它是Angular表单中的最小单元。
  3、FormControl封装了这些字段的值和状态,比如是否有效、是否脏(被修改过)或是否有错误等。
  4、大多数表单都拥有不止一个字段,因此我们需要某种方式来管理多个FormControl。假设我们要检查表单的有效性。如果要遍历这个FormControl数组并检查每一个FormControl是否有效,必然相当繁琐;而FormGroup则可以为一组FormControl提供总包接口(wrapperinterface),来解决这种问题。

代码素材

  你可以在以下git代码中找到我上述讲述的知识点的实例代码(angular的实例代码中的angular-form)代码中对如何创建模板驱动型表单,响应式表单、使用FormBuilder创建响应式表单、创建自定义指令(响应式表单的和模板驱动表单的自定义指令都有)以及深层次传递表单控制等知识点都有涉及到。

angular表单知识点的更多相关文章

  1. Javascript中的Form表单知识点总结

    Javascript中的Form表单知识点总结 在HTML中,表单是由form元素来表示的,但是在javascript中,表单则由HTMLFormElement类型,此元素继承了HTMLElement ...

  2. Angular 表单(二) - 模板驱动表单

    import { Component, OnInit } from '@angular/core'; import { Hero} from '../hero'; @Component({ selec ...

  3. angular表单经验分享

    原文 https://www.jianshu.com/p/af359bd04f32 大纲 1.表单的名字不可以和传入的值的名字相同 2.在模板驱动表单的时候要使用angular表单的验证功能,需要将n ...

  4. Angular 表单验证类库 ngx-validator 1.0 正式发布

    背景介绍 之前写了一篇 <如何优雅的使用 Angular 表单验证>,结尾处介绍了统一验证反馈的类库  ngx-validator  ,由于这段时间一直在新模块做微前端以及相关业务组件库, ...

  5. Angular表单 (一)表单简介

    Angular 表单 angular提供了两种不同的方法来通过表单处理用户输入:响应式表单和模板驱动表单.二者都从视图中捕获用户输入事件.验证用户输入.创建表单模型.修改数据模型,并提供跟踪这些更改的 ...

  6. Angular表单验证

    novalidate   去掉html5自带的验证 ng-minlength    规定输入文本的最小长度 ng-maxlength    规定输入文本的最大长度 ng-submit  接收一个方法名 ...

  7. angular表单的使用实例

    原文 https://www.jianshu.com/p/da1fd5396798 大纲 1.模板驱动表单的创建 2.响应式表单的创建 3.模板驱动型表单的自定义指令 4.响应式表单的自定义指令 5. ...

  8. angular表单

    angular的表单,点击确定进行创建,支持批量创建,表单验证有样式提醒; <!DOCTYPE html> <html lang="en"> <hea ...

  9. 简单的angular表单验证指令

    <html ng-app="myApp"> <head> <meta charset="UTF-8"> <title& ...

随机推荐

  1. Tomcat之虚拟主机配置以及web应用配置

    Tomcat之虚拟主机配置以及web应用配置 Tomcat文件夹结构例如以下: bin ---- 启动和关闭须要的bat文件所在的文件夹 conf --- 配置文件夹 lib ---  tomcat执 ...

  2. [Redux-Observable && Unit Testing] Use tests to verify updates to the Redux store (rxjs scheduler)

    In certain situations, you care more about the final state of the redux store than you do about the ...

  3. Java开发者最经常使用19个Linux命令

    1.查找文件 find / -name filename.txt 依据名称查找/文件夹下的filename.txt文件. 2.查看一个程序是否执行 ps –ef|grep tomcat 查看全部有关t ...

  4. HDOJ 5399 Too Simple

    每个函数都必须是一个排列,经过连续的一段确定函数后数字不能少. 满足上面的条件的话,仅仅要有一个-1函数特别的排列一下就能够满足要求,剩下的能够任意填 没有-1的话特判 Too Simple Time ...

  5. searchView-风格调整

    5.1以后的searchView 风格调整属性相比于4.4有了些更改.我们先看代码 <style name="DeskClock.Theme" parent="an ...

  6. actionBar-双行字体大小修改

    <style name="BackupRestore.Theme.Person" parent="@style/BackupRestore.Theme"& ...

  7. [NowCoder]牛客OI周赛3

    A.地斗主 题意:\(4\times N\) 的地板,在上面铺 \(1\times 2\) 和 \(2\times 1\) 的地砖,求铺满方案数, \(N\le 10^9\) 原题..先把一列的状态压 ...

  8. 35.Intellij IDEA设置忽略部分类编译错误

    转自:https://www.aliyun.com/jiaocheng/290360.html 有些时候我们的项目中有些错误,但这些错误并不影响项目的整体运行(或许是没有使用到),默认情况下idea是 ...

  9. Flask设置配置文件

    Flask修改配置: from flask import Flask app = Flask(__name__) app.config['DEBUG'] = True @app.route('/') ...

  10. Mongodb总结3-稍微封装一下

    上次发表的2,纯粹是Demo,演示API的用法. 今天,稍微封装了下,看得更清楚. 考虑到不容易做得很有通用性,所以封装的一般,换种场景需要直接修改代码,但是有一部分是可以复用的. 最近项目,很可能只 ...