原文

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. 【Codeforces Round #457 (Div. 2) B】Jamie and Binary Sequence

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 把n分解成二进制的形式. n=2^a0+2^a1+...+2^a[q-1] 则固定就是长度为q的序列. 要想扩展为长为k的序列. 可 ...

  2. 洛谷 P1881 绳子对折

    P1881 绳子对折 题目描述 FJ 有一个长度为L(1<= L <= 10,000)的绳子. 这个绳子上有N(1 <= N <= 100)个结,包括两个端点. FJ想将绳子对 ...

  3. Hive通过查询语句向表中插入数据过程中发现的坑

    前言 近期在学习使用Hive(版本号0.13.1)的过程中,发现了一些坑,它们也许是Hive提倡的比关系数据库更加自由的体现(同一时候引来一些问题).也许是一些bug.总而言之,这些都须要使用Hive ...

  4. Axios再记录

    一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端(可实现ajax的请求) 有关学习网址:https://www.tuicool.com/articles/eMb2yuY    ...

  5. [React] Compound Component (React.Children.map & React.cloneElement)

    Imaging you are building a Tabs component. If looks like: <Tabs> <TabList> <Tab> o ...

  6. JavaScript作用域闭包(你不知道的JavaScript)

    JavaScript闭包.是JS开发project师必须深入了解的知识. 3月份自己曾撰写博客<JavaScript闭包>.博客中仅仅是简单阐述了闭包的工作过程和列举了几个演示样例,并没有 ...

  7. c# 查询sql 返回多个參数

    1.依据须要查询mysql 语句,返回三个须要的參数,不是数据集 2.编写函数例如以下: public static void GetParas(string 条件1, out string 返回值1 ...

  8. Android学习笔记之Bitmap位图虽触摸点移动

    package xiaosi.bitmap; import android.app.Activity; import android.os.Bundle; public class mianActiv ...

  9. 数据类型的提升(promotion)

    假如参与运算的数据类型不同或者取值范围过小,编译器会自动将其转换为相同的类型,这个类型就叫数据类型的提升(promotion). 1. C++ 语言环境的规定 unsigned char a = 17 ...

  10. python文件的操作

    文件的操作,归根结底就只有两种:打开文件.操作文件 一.打开文件:文件句柄 = open('文件路径', '模式') python中打开文件有两种方式,即:open(...) 和  file(...) ...