angular表单的使用实例
原文
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表单的使用实例的更多相关文章
- angular表单经验分享
原文 https://www.jianshu.com/p/af359bd04f32 大纲 1.表单的名字不可以和传入的值的名字相同 2.在模板驱动表单的时候要使用angular表单的验证功能,需要将n ...
- Angular表单 (一)表单简介
Angular 表单 angular提供了两种不同的方法来通过表单处理用户输入:响应式表单和模板驱动表单.二者都从视图中捕获用户输入事件.验证用户输入.创建表单模型.修改数据模型,并提供跟踪这些更改的 ...
- 【干货】Laravel --Validate (表单验证) 使用实例
前言 : Laravel 提供了多种方法来验证应用输入数据.默认情况下,Laravel 的控制器基类使用ValidatesRequests trait,该trait提供了便利的方法通过各种功能强大的验 ...
- Angular 表单(二) - 模板驱动表单
import { Component, OnInit } from '@angular/core'; import { Hero} from '../hero'; @Component({ selec ...
- jquery实现表单验证简单实例
/* 描述:基于jquery的表单验证插件. */ (function ($) { $.fn.checkForm = function (options) { var root = this; //将 ...
- PHP通过session判断防止表单重复提交实例
PHP通过session判断防止表单重复提交实例,当用户提交表单后,为防止重复操作,通过session来判断是否为初次提交,否则让他返回到之前表单页面. 当前表单页面is_submit设为0 SESS ...
- Angular 表单验证类库 ngx-validator 1.0 正式发布
背景介绍 之前写了一篇 <如何优雅的使用 Angular 表单验证>,结尾处介绍了统一验证反馈的类库 ngx-validator ,由于这段时间一直在新模块做微前端以及相关业务组件库, ...
- angular表单验证实例----可用的代码
前段时间,公司做一个单页面,就是一个表单验证,早开始在菜鸟教程上关注了angular,所以下派上用场了 angular里面对于表单验证,设置了很多指令. 也就是说不用自己写一些逻辑,直接绑定指令就行. ...
- angular 响应式表单(登录实例)
一.表单验证 1. 只有一个验证规则: this.myGroup = this.fb.group({ email:['hurong.cen@qq.com',Validators.required], ...
随机推荐
- Duboo入门示例(Idea开发环境)
在学习Dubbo分布式框架时的官方入门例子,很有代表性.简单清晰. 有关Dubbo的概念.概述和简单的配置文件,可以看官方文档的简述 会很快对Duboo有个整体的概念. 准备工作: 下载示例,点击这里 ...
- 开源 java CMS - FreeCMS2.3会员积分记录
原文地址:http://javaz.cn/site/javaz/site_study/info/2015/28995.html 项目地址:http://www.freeteam.cn/ 积分记录 从 ...
- CodeForce 424C Magic Formulas
这个题就是求出给的公式的结果. 仅仅要知道异或运算满足交换律跟结合律即可了.之后就是化简公式. #include<map> #include<string> #include& ...
- Hibernate之关于多对多单向关联映射
[Hibernate]之关于多对多单向关联映射 老师和学生,最典型的多对多关联, Teacher和Student.所谓单向意思就是说.老师知道自己的教的是哪些学生而学生不知道是哪些老师教. 也能够这么 ...
- Drupal 关于节点(nodes)的理解
在 Drupal 构建的站点中.全部的内容都是以节点形式存储的,一个节点能够是公布的不论什么一个内容,比方说一个单面(page).一个投票(Poll).一篇文章(article).论坛主题(forum ...
- 10lession-if-else条件语句
python的条件选择语句跟其他语言的及其相似,这里就不做详细记录,仅仅是看个例子好了 #!/usr/bin/python "]: print('1 in [1,2,3,"4&qu ...
- php数组插入数据
php数组插入数据 一.总结 代码要多敲,看是看不会的 php代码直接在页面不好敲,可以去控制器里面敲 二.目标 在一组数中,要求插入一个数,按其原来顺序插入,维护原来排序方式. 三.代码 (1).思 ...
- IE中实现placeholder
简介:IE本身不支持Placeholder这种先进的特性,但是我们又必须且仅仅支持IE,所以网上找了一个支持placeholder的方法 考虑版权,以及知识产权原因,只放链接: http://blog ...
- Python中对于GIL全局解释器锁的一点理解
GIL全局解释器锁 python最初开发时,开发人只考虑到了单核CPU的,为解决多线程运算之间的数据完整性和状态同步选择了加锁的方式.即GIL锁. 而目前的CPU都有多个核心,在运行python的某个 ...
- Xcode6:No architectures to compile for(ONLY_ACTIVE_ARCH=YES...)
1.问题描写叙述 Xcode6真机測试旧project,不能执行,报错例如以下: 2.解决方式 问题非常明显,当前的执行模式设置了ONLY_ACTIVE_ARCH为Yes,当时的project的Val ...