原文

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

大纲

  1、模板驱动表单的创建
  2、响应式表单的创建
  3、模板驱动型表单的自定义指令
  4、响应式表单的自定义指令
  5、父组件向子组件传递表单控制
  6、代码素材

模板驱动表单的创建

//1、在根模块注入依赖模块
import { FormsModule } from '@angular/forms';
//2、在模板中创建表单控件
<form>
<div class="form-group">
<label class="center-block">Name1:
<input class="form-control">
</label>
</div>
<div class="form-group">
<label class="center-block">Age1:
<input class="form-control">
</label>
</div>
</form>
//3、在模板中添加ngModel同步数据
//4、数据校验:模板型表单的数据校验是写在模板上的,
//将require、minlength等校验规则写在模板上,从而定义对应表单控件的校验规则
//5、表单的提交,可以通过提交被监控的表单的值来达到表单的提交
//6、可以自定义设置表单数据的校验

响应式表单的创建

//1、在根模块注入依赖模块,引入ReactiveFormsModule
import { ReactiveFormsModule } from '@angular/forms';
//2、在模板中创建form表单
//3、在组件中创建响应式表单控制器
ReactiveForm = new FormGroup({
age: new FormControl('',[Validators.required])
});
//4、监控表单的值的变化
/*
a:数据模型的值的变化:这里同样需要ngModel来绑定数据模型和表单模型的值,
不过需要注意的是,如果用ngModel来绑定表单控件,
那么通过new FormControl设置的默认值可能就会被ngModel的默认值给覆盖了
b:表单模型的值的变化:可以通过监控{{ReactiveForm.value.age}}来监控值的变化
*/
//5、数据的校验
/*
各个表单控件的数据的校验是需要通过FormControl来设置的,
可以看到每个new FormControl后都可以对各个表单控件进行数据的校验。
*/
//6、表单的提交
/*
(ngSubmit)="onSubmit(user)"通过ngSumbit即可实现表单数据的提交,
user是表单的名字,即:[formGroup]="user"
*/
//7、可以自定义设置表单数据的校验

模板驱动型表单的自定义指令

  模板型表单校验需要通过模板中添加属性才可以添加验证,所以需要继承指令Directive,在Directive中定义元数据并添加一系列的自定义的表单校验规则。

/**
equalCrk.direvtive.ts
使用:
<input name="nickName" id="nickName" [(ngModel)]='nickName' validateCrk>
当输入的数据不是crk的时候,表单的校验是不会通过的
**/
import { Directive, forwardRef, Attribute } from '@angular/core';
import { NG_VALIDATORS, Validator, AbstractControl } from '@angular/forms'; @Directive({
selector: '[validateCrk][ngModel]',
providers: [
{
provide: NG_VALIDATORS,
useExisting: forwardRef(() => CrkValidatorDirective),
multi: true
}
]
})
export class CrkValidatorDirective implements Validator {
constructor(
@Attribute('validateCrk') public validateCrk: string) {
}
validate(c: AbstractControl): { [key: string]: any } {
// 控件自身值
const self = c.value;
// 控件的值是否等于'crk'
if (self !== 'crk') {
return {
validateCrk: true
};
}
return null;
}
}

响应式表单的自定义指令

  响应式的自定义校验相对来说较简单,需要满足ValidatorFn即可。

/**
响应式表单自定义指令
使用:
{validator: [this.validateEqualCrk('nickName','gg')]}
*/
validateEqualCrk(confirmKey: string, confirmStr?:string): ValidatorFn {
return (group: FormGroup): {[key: string]: any} => {
const confirmField = group.controls[confirmKey];
const pattenStr = confirmStr ? confirmStr : 'crk'
if (confirmField.value !== pattenStr) {
return {
validateEqualCrk: true
};
}
return null;
};
}

父组件向子组件传递表单控制

  当表单中某个字段是以子组件的形式出现的时候,不能直接设置FormControl,因此需要向子组件传递FormControl然后在子组件添加,这样才可以实现父组件表单对子组件表单元素的控制。

代码素材

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

angular表单的使用实例的更多相关文章

  1. angular表单经验分享

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

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

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

  3. 【干货】Laravel --Validate (表单验证) 使用实例

    前言 : Laravel 提供了多种方法来验证应用输入数据.默认情况下,Laravel 的控制器基类使用ValidatesRequests trait,该trait提供了便利的方法通过各种功能强大的验 ...

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

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

  5. jquery实现表单验证简单实例

    /* 描述:基于jquery的表单验证插件. */ (function ($) { $.fn.checkForm = function (options) { var root = this; //将 ...

  6. PHP通过session判断防止表单重复提交实例

    PHP通过session判断防止表单重复提交实例,当用户提交表单后,为防止重复操作,通过session来判断是否为初次提交,否则让他返回到之前表单页面. 当前表单页面is_submit设为0 SESS ...

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

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

  8. angular表单验证实例----可用的代码

    前段时间,公司做一个单页面,就是一个表单验证,早开始在菜鸟教程上关注了angular,所以下派上用场了 angular里面对于表单验证,设置了很多指令. 也就是说不用自己写一些逻辑,直接绑定指令就行. ...

  9. angular 响应式表单(登录实例)

    一.表单验证 1. 只有一个验证规则: this.myGroup = this.fb.group({ email:['hurong.cen@qq.com',Validators.required], ...

随机推荐

  1. 【习题 8-7 UVA - 11925】Generating Permutations

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 让你把排列1..n变换成对应的输入序列. 每次可以交换前两个数字,或者把第一个数字放到末尾去. 可以逆向考虑. 即把无序的序列变换成 ...

  2. HDU1050:Moving Tables

    pid=1050">Moving Tables Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 ...

  3. node----ajax请求太大报错------解决方法

    //----分析主体程序var bodyParser = require(‘body-parser‘); app.use(bodyParser.json({limit: ‘50mb‘})); app. ...

  4. [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.0:compile (default-compile) 问题解决

    问题描述详情: 无论你的问题是3.0还是3.1还是任何一个版本,则都可以通过以下版本来解决 解决办法: 把默认的Internal JRE改成了JAVA_HOME. 运行后成功了,截图如下:

  5. BZOJ4044: [Cerc2014] Virus synthesis(回文树+DP)

    Description Viruses are usually bad for your health. How about fighting them with... other viruses? ...

  6. 你真的懂Flask中浅谈蓝图Blueprint吗?

    一,什么是Flask中的蓝图Blueprint Blueprint是用于实现Flask框架中单个应用的视图,模板,静态文件的集合. Blueprint 是一个存储操作(路由映射)方法的容器,这些操作在 ...

  7. Android Studio中怎样引用图片资源

    随着不断接触Android Studio,越来越发现和Eclipse有着巨大的差别. 不管是表面的目录结构,还是内在对各种资源的管理. 本篇就来聊聊Android Studio中怎样来显示图片. 以及 ...

  8. HDU 2068 RPG的错排(错排公式 + 具体解释)

    RPG的错排 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

  9. Linux 网卡驱动学习(九)(层二转发)

    1.mac 地址表的自学习过程 port1上的A计算机要与port2上的B计算机通信时,A发到交换机上,交换机收到信息后,交换机先记录发port1所相应的a的mac地址并记录在自己的mac表中,然后再 ...

  10. 10.Maven依赖排除 禁止依赖传递 取消依赖的方法

    转自:https://www.cnblogs.com/duanxz/p/6084494.html 大家都知道Maven的优点是依赖管理,特别是前期使用ANT的开发者都有很多感触.最近要开发一个java ...