1:安装模块

npm install ng2-validation --save

2:配置app.module.ts

import { FormsModule, <font color="Red">ReactiveFormsModule</font> } from '@angular/forms';
import {<font color="Red">CustomFormsModule</font>} from "ng2-validation";
...
imports: [
FormsModule,
<font color="Red">CustomFormsModule,</font>
<font color="Red">ReactiveFormsModule</font>
],
...

3:表单验证有两种方式 <1> 模板驱动       <2>模型驱动

接下来我们看下 模板驱动  只有一个步骤 <1>  配置模版文件     ts文件不需要做什么
app-ttemplate-driven.component.html

<div class="container">
<form (ngSubmit)="onSubmit()" #validationForm="ngForm">
<div class="form-group">
<label for="appField">长度要求</label>
<input type="text" required class="form-control" name="appField" [(ngModel)]="model.appField" #rangeLength="ngModel" [rangeLength]="[5, 9]">
<p [hidden]="rangeLength.valid||rangeLength.pristine">长度在5到9之间</p>
</div>
<div class="form-group">
<label for="appField2">长度要求2</label>
<input type="text" class="form-control" name="appField2" [(ngModel)]="model.appField2" #rangeLength2="ngModel" [rangeLength]="[0,5]">
<p [hidden]="rangeLength2.valid||rangeLength2.pristine">长度要求</p>
</div>
<div class="form-group">
<label for="appMin">最小值</label>
<input type="number" class="form-control" name="appMin" [(ngModel)]="model.appMin" #appMin="ngModel" [min]="" />
<p [hidden]="appMin.valid||appMin.pristine">取值大于等于10</p>
</div>
<div class="form-group">
<label for="appGt">大于</label>
<input type="number" class="form-control" name="appGt" [(ngModel)]="model.appGt" #appGt="ngModel" [gt]="" />
<p [hidden]="appGt.valid||appGt.pristine">取值大于10</p>
</div>
<div class="form-group">
<label for="appGte">大于等于</label>
<input type="number" class="form-control" name="appGte" [(ngModel)]="model.appGte" #appGte="ngModel" [gte]="" />
<p [hidden]="appGte.valid||appGte.pristine">取值大于等于10</p>
</div>
<div class="form-group">
<label for="appMax">最大值</label>
<input type="number" class="form-control" name="appMax" [(ngModel)]="model.appMax" #appMax="ngModel" [max]="" />
<p [hidden]="appMax.valid||appMax.pristine">最小值10</p>
</div>
<div class="form-group">
<label for="appLt">小于</label>
<input type="number" class="form-control" name="appLt" [(ngModel)]="model.appLt" #appLt="ngModel" [lt]="" />
<p [hidden]="appLt.valid||appLt.pristine">值小于10</p>
</div>
<div class="form-group">
<label for="appLte">小于等于</label>
<input type="number" class="form-control" name="appLte" [(ngModel)]="model.appLte" #appLte="ngModel" [lte]="" />
<p [hidden]="appLte.valid||appLte.pristine">值小于等于10</p>
</div>
<div class="form-group">
<label for="appRange">取值范围</label>
<input type="number" class="form-control" name="appRange" [(ngModel)]="model.appRange" #appRange="ngModel" [range]="[10, 20]" />
<p [hidden]="appRange.valid||appRange.pristine">取值大于等于10到小于等于20</p>
</div>
<div class="form-group">
<label for="appDigits">数字</label>
<input type="text" class="form-control" name="appDigits" [(ngModel)]="model.appDigits" #appDigits="ngModel" digits />
<p [hidden]="appDigits.valid||appDigits.pristine">必须是uint</p>
</div>
<div class="form-group">
<label for="appNumber">数字</label>
<input type="text" class="form-control" name="appNumber" [(ngModel)]="model.appNumber" #appNumber="ngModel" number />
<p [hidden]="appNumber.valid||appNumber.pristine">任何数字</p>
</div>
<div class="form-group">
<label for="appUrl">链接</label>
<input type="text" class="form-control" name="appUrl" [(ngModel)]="model.appUrl" #appUrl="ngModel" url />
<p [hidden]="appUrl.valid||appUrl.pristine">合法的url</p>
</div>
<div class="form-group">
<label for="appEmail">邮箱</label>
<input type="text" class="form-control" name="appEmail" [(ngModel)]="model.appEmail" #appEmail="ngModel" email />
<p [hidden]="appEmail.valid||appEmail.pristine">合法的邮箱地址</p>
</div>
<div class="form-group">
<label for="appDate">日期</label>
<input type="text" class="form-control" name="appDate" [(ngModel)]="model.appDate" #appDate="ngModel" date />
<p [hidden]="appDate.valid||appDate.pristine">合法的日期</p>
</div>
<div class="form-group">
<label for="appUuid">uuid</label>
<input type="text" class="form-control" name="appUuid" [(ngModel)]="model.appUuid" #appUuid="ngModel" uuid="'all'" />
<p [hidden]="appUuid.valid||appUuid.pristine">不是合法的uuid</p>
</div>
<div class="form-group">
<label for="appPhone">电话</label>
<input type="text" class="form-control" name="appPhone" [(ngModel)]="model.appPhone" #appPhone="ngModel" phone="CN" />
<p [hidden]="appPhone.valid||appPhone.pristine">不是合法的电话号码</p>
</div>
<div class="form-group">
<label >两次相同</label>
<input class="form-control" type="password" ngModel name="appPassword" #appPassword="ngModel" required/>
<p [hidden]="appPassword.valid||appPassword.pristine">必填项</p>
<input class="form-control" type="password" ngModel name="appCertainPassword" #appCertainPassword="ngModel" [equalTo]="appPassword"/>
<p [hidden]="appCertainPassword.valid||appCertainPassword.pristine">两次输入不一致</p>
</div>
<div class="form-group">
<label for="appEqual">相同</label>
<input type="text" class="form-control" name="appEqual" [(ngModel)]="model.appEqual" #appEqual="ngModel" [equal]="'哈哈'" />
<p [hidden]="appEqual.valid||appEqual.pristine">与值不相符</p>
</div>
<div class="form-group">
<label for="appComplex">复合条件</label>
<input type="number" class="form-control" name="appComplex" [(ngModel)]="model.appComplex" #appComplex="ngModel" [gte]="" [max]="" />
<p [hidden]="appComplex.valid||appComplex.pristine">大于等于5,最大是10</p>
</div>
<button type="submit" [disabled]="!validationForm.form.valid" class="btn btn-default">Submit</button>
</form>
</div>

接下来我们看下 模型驱动, 分两个步骤 <1> 配置组件.ts文件     <2> 配置模版文件
app-model-driven.component.ts

import { Component, OnInit } from '@angular/core';
import { FormGroup, FormControl, Validators } from "@angular/forms";
import { CustomValidators } from 'ng2-validation'; @Component({
selector: 'app-app-model-driven',
templateUrl: './app-model-driven.component.html',
styleUrls: ['./app-model-driven.component.css']
})
export class AppModelDrivenComponent implements OnInit {
public formGroup: FormGroup;
password:string="";
constructor() {
let password = new FormControl('', [Validators.required]);
let certainPassword = new FormControl('', CustomValidators.equalTo(password));
this.formGroup = new FormGroup({
field: new FormControl('', CustomValidators.rangeLength([, ])),
appGt:new FormControl('', CustomValidators.gt()),
password:password,
certainPassword:certainPassword,
maxField:new FormControl('',[CustomValidators.gt(),CustomValidators.max()])
});
} ngOnInit() {
}
onSubmit(){}
}

app-model-driven.component.html

<div class="container">
<form [formGroup]="formGroup" (ngSubmit)="onSubmit()" #validationForm2="ngForm" >
<div class="form-group" >
<input class="form-control" name="field" type="text" formControlName="field"/>
<p *ngIf="validationForm2.form.controls.field.errors?.rangeLength">长度在5到9之间</p>
<p>{{validationForm2.form.controls.field.errors?.rangeLength}}</p>
</div>
<div class="form-group" >
<input class="form-control" name="appGt" type="number" formControlName="appGt"/>
<p *ngIf="validationForm2.form.controls.appGt.errors?.gt">大于10</p>
</div>
<div class="form-group" >
<input class="form-control" name="password" type="password" [(ngModel)]="password" formControlName="password"/>
<p *ngIf="validationForm2.form.controls.password.errors?.required">必填</p>
<p>{{test.pristine}}</p>
<input class="form-control" type="password" formControlName="certainPassword"/>
<p *ngIf="validationForm2.form.controls.certainPassword.errors?.equalTo">两次相同</p>
</div>
<div class="form-group" >
<label for="appMin">组合形式</label>
<input type="number" class="form-control" name="appMin" formControlName="maxField" />
<p [hidden]="!validationForm2.form.controls.maxField.errors?.max &&!validationForm2.form.controls.maxField.errors?.gt">取值大于等于10且小于20</p>
</div>
<button type="submit" [disabled]="!validationForm2.form.valid" class="btn btn-default">Submit</button>
</form>
</div>

官方文档:ng2-validation

1:安装模块

  1. npm install ng2-validation --save

复制代码

2:配置app.module.ts

  1. import { FormsModule, <font color="Red">ReactiveFormsModule</font> } from '@angular/forms';
  2. import {<font color="Red">CustomFormsModule</font>} from "ng2-validation";
  3. ...
  4. imports: [
  5. FormsModule,
  6. <font color="Red">CustomFormsModule,</font>
  7. <font color="Red">ReactiveFormsModule</font>
  8. ],
  9. ...

复制代码

3:表单验证有两种方式 <1> 模板驱动       <2>模型驱动

接下来我们看下 模板驱动  只有一个步骤 <1>  配置模版文件     ts文件不需要做什么
app-ttemplate-driven.component.html

  1. <div class="container">
  2. <form (ngSubmit)="onSubmit()" #validationForm="ngForm">
  3. <div class="form-group">
  4. <label for="appField">长度要求</label>
  5. <input type="text" required class="form-control"
    name="appField" [(ngModel)]="model.appField" #rangeLength="ngModel"
    [rangeLength]="[5, 9]">
  6. <p [hidden]="rangeLength.valid||rangeLength.pristine">长度在5到9之间</p>
  7. </div>
  8. <div class="form-group">
  9. <label for="appField2">长度要求2</label>
  10. <input type="text"  class="form-control"
    name="appField2" [(ngModel)]="model.appField2" #rangeLength2="ngModel"
    [rangeLength]="[0,5]">
  11. <p [hidden]="rangeLength2.valid||rangeLength2.pristine">长度要求</p>
  12. </div>
  13. <div class="form-group">
  14. <label for="appMin">最小值</label>
  15. <input type="number"  class="form-control" name="appMin" [(ngModel)]="model.appMin"  #appMin="ngModel" [min]="10" />
  16. <p [hidden]="appMin.valid||appMin.pristine">取值大于等于10</p>
  17. </div>
  18. <div class="form-group">
  19. <label for="appGt">大于</label>
  20. <input type="number" class="form-control" name="appGt" [(ngModel)]="model.appGt" #appGt="ngModel" [gt]="10" />
  21. <p [hidden]="appGt.valid||appGt.pristine">取值大于10</p>
  22. </div>
  23. <div class="form-group">
  24. <label for="appGte">大于等于</label>
  25. <input type="number" class="form-control" name="appGte" [(ngModel)]="model.appGte" #appGte="ngModel" [gte]="10" />
  26. <p [hidden]="appGte.valid||appGte.pristine">取值大于等于10</p>
  27. </div>
  28. <div class="form-group">
  29. <label for="appMax">最大值</label>
  30. <input type="number" class="form-control" name="appMax" [(ngModel)]="model.appMax" #appMax="ngModel" [max]="10" />
  31. <p [hidden]="appMax.valid||appMax.pristine">最小值10</p>
  32. </div>
  33. <div class="form-group">
  34. <label for="appLt">小于</label>
  35. <input type="number" class="form-control" name="appLt" [(ngModel)]="model.appLt" #appLt="ngModel" [lt]="10" />
  36. <p [hidden]="appLt.valid||appLt.pristine">值小于10</p>
  37. </div>
  38. <div class="form-group">
  39. <label for="appLte">小于等于</label>
  40. <input type="number" class="form-control" name="appLte" [(ngModel)]="model.appLte" #appLte="ngModel" [lte]="10" />
  41. <p [hidden]="appLte.valid||appLte.pristine">值小于等于10</p>
  42. </div>
  43. <div class="form-group">
  44. <label for="appRange">取值范围</label>
  45. <input type="number" class="form-control"
    name="appRange" [(ngModel)]="model.appRange" #appRange="ngModel"
    [range]="[10, 20]" />
  46. <p [hidden]="appRange.valid||appRange.pristine">取值大于等于10到小于等于20</p>
  47. </div>
  48. <div class="form-group">
  49. <label for="appDigits">数字</label>
  50. <input type="text" class="form-control" name="appDigits" [(ngModel)]="model.appDigits" #appDigits="ngModel" digits />
  51. <p [hidden]="appDigits.valid||appDigits.pristine">必须是uint</p>
  52. </div>
  53. <div class="form-group">
  54. <label for="appNumber">数字</label>
  55. <input type="text" class="form-control" name="appNumber" [(ngModel)]="model.appNumber" #appNumber="ngModel" number />
  56. <p [hidden]="appNumber.valid||appNumber.pristine">任何数字</p>
  57. </div>
  58. <div class="form-group">
  59. <label for="appUrl">链接</label>
  60. <input type="text" class="form-control" name="appUrl" [(ngModel)]="model.appUrl" #appUrl="ngModel" url />
  61. <p [hidden]="appUrl.valid||appUrl.pristine">合法的url</p>
  62. </div>
  63. <div class="form-group">
  64. <label for="appEmail">邮箱</label>
  65. <input type="text" class="form-control" name="appEmail" [(ngModel)]="model.appEmail" #appEmail="ngModel" email />
  66. <p [hidden]="appEmail.valid||appEmail.pristine">合法的邮箱地址</p>
  67. </div>
  68. <div class="form-group">
  69. <label for="appDate">日期</label>
  70. <input type="text" class="form-control" name="appDate" [(ngModel)]="model.appDate" #appDate="ngModel" date />
  71. <p [hidden]="appDate.valid||appDate.pristine">合法的日期</p>
  72. </div>
  73. <div class="form-group">
  74. <label for="appUuid">uuid</label>
  75. <input type="text" class="form-control" name="appUuid" [(ngModel)]="model.appUuid" #appUuid="ngModel" uuid="'all'" />
  76. <p [hidden]="appUuid.valid||appUuid.pristine">不是合法的uuid</p>
  77. </div>
  78. <div class="form-group">
  79. <label for="appPhone">电话</label>
  80. <input type="text" class="form-control" name="appPhone"
    [(ngModel)]="model.appPhone" #appPhone="ngModel" phone="CN" />
  81. <p [hidden]="appPhone.valid||appPhone.pristine">不是合法的电话号码</p>
  82. </div>
  83. <div class="form-group">
  84. <label >两次相同</label>
  85. <input class="form-control"  type="password" ngModel name="appPassword" #appPassword="ngModel" required/>
  86. <p [hidden]="appPassword.valid||appPassword.pristine">必填项</p>
  87. <input class="form-control"  type="password" ngModel
    name="appCertainPassword" #appCertainPassword="ngModel"
    [equalTo]="appPassword"/>
  88. <p [hidden]="appCertainPassword.valid||appCertainPassword.pristine">两次输入不一致</p>
  89. </div>
  90. <div class="form-group">
  91. <label for="appEqual">相同</label>
  92. <input type="text" class="form-control" name="appEqual"
    [(ngModel)]="model.appEqual" #appEqual="ngModel" [equal]="'哈哈'" />
  93. <p [hidden]="appEqual.valid||appEqual.pristine">与值不相符</p>
  94. </div>
  95. <div class="form-group">
  96. <label for="appComplex">复合条件</label>
  97. <input type="number" class="form-control"
    name="appComplex" [(ngModel)]="model.appComplex" #appComplex="ngModel"
    [gte]="5" [max]="10"  />
  98. <p [hidden]="appComplex.valid||appComplex.pristine">大于等于5,最大是10</p>
  99. </div>
  100. <button type="submit" [disabled]="!validationForm.form.valid" class="btn btn-default">Submit</button>
  101. </form>
  102. </div>

复制代码

接下来我们看下 模型驱动, 分两个步骤 <1> 配置组件.ts文件     <2> 配置模版文件
app-model-driven.component.ts

  1. import { Component, OnInit } from '@angular/core';
  2. import { FormGroup, FormControl, Validators } from "@angular/forms";
  3. import { CustomValidators } from 'ng2-validation';
  4. @Component({
  5. selector: 'app-app-model-driven',
  6. templateUrl: './app-model-driven.component.html',
  7. styleUrls: ['./app-model-driven.component.css']
  8. })
  9. export class AppModelDrivenComponent implements OnInit {
  10. public formGroup: FormGroup;
  11. password:string="";
  12. constructor() {
  13. let password = new FormControl('', [Validators.required]);
  14. let certainPassword = new FormControl('', CustomValidators.equalTo(password));
  15. this.formGroup = new FormGroup({
  16. field: new FormControl('',  CustomValidators.rangeLength([5, 9])),
  17. appGt:new FormControl('', CustomValidators.gt(10)),
  18. password:password,
  19. certainPassword:certainPassword,
  20. maxField:new FormControl('',[CustomValidators.gt(10),CustomValidators.max(20)])
  21. });
  22. }
  23. ngOnInit() {
  24. }
  25. onSubmit(){}
  26. }

复制代码

app-model-driven.component.html

  1. <div class="container">
  2. <form [formGroup]="formGroup" (ngSubmit)="onSubmit()" #validationForm2="ngForm" >
  3. <div class="form-group" >
  4. <input class="form-control" name="field"  type="text"  formControlName="field"/>
  5. <p *ngIf="validationForm2.form.controls.field.errors?.rangeLength">长度在5到9之间</p>
  6. <p>{{validationForm2.form.controls.field.errors?.rangeLength}}</p>
  7. </div>
  8. <div class="form-group" >
  9. <input class="form-control" name="appGt" type="number"  formControlName="appGt"/>
  10. <p *ngIf="validationForm2.form.controls.appGt.errors?.gt">大于10</p>
  11. </div>
  12. <div class="form-group" >
  13. <input class="form-control" name="password" type="password" [(ngModel)]="password" formControlName="password"/>
  14. <p *ngIf="validationForm2.form.controls.password.errors?.required">必填</p>
  15. <p>{{test.pristine}}</p>
  16. <input class="form-control" type="password" formControlName="certainPassword"/>
  17. <p *ngIf="validationForm2.form.controls.certainPassword.errors?.equalTo">两次相同</p>
  18. </div>
  19. <div class="form-group" >
  20. <label for="appMin">组合形式</label>
  21. <input type="number"  class="form-control" name="appMin" formControlName="maxField" />
  22. <p
    [hidden]="!validationForm2.form.controls.maxField.errors?.max
    &&!validationForm2.form.controls.maxField.errors?.gt">取值大于等于10且小于20</p>
  23. </div>
  24. <button type="submit" [disabled]="!validationForm2.form.valid" class="btn btn-default">Submit</button>
  25. </form>
  26. </div>

复制代码

官方文档:ng2-validation

angular2 ng2-validation 表单验证的更多相关文章

  1. jQuery学习之:Validation表单验证插件

    http://polaris.blog.51cto.com/1146394/258781/ 最近由于公司决定使用AJAX + Struts2来重构项目,让我仔细研究一下这两个,然后集中给同事讲讲,让每 ...

  2. jquery validation表单验证插件。

    这个是刚学的,觉得对以后挺有用的,就想把自己所学的分享一下. 校验规则: (1)required:true 必输字段 (2)number:true 必须输入合法的数字(负数,小数) (3)digits ...

  3. jquery validation表单验证插件2。

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  4. jQuery之Validation表单验证插件使用

    <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head> <met ...

  5. 实例讲解表单验证插件Validation的应用

    jquery.Validation是一款优秀的jquery插件,它能对客户端表单进行验证,并且提供了许多可以定制的属性和方法,良好的扩展性.现在 结合实际情况,我把项目中经常要用到的验证整理成一个实例 ...

  6. 好用的表单验证工具 vuelidate

    Vue validation(表单验证)--vuelidate 表单是用户那里收集的数据的工具.如果它没有收集到你需要的数据,或者收集到的数据不对,那么你的表单就没有达到它的目的.这就是为什么我们需要 ...

  7. jQuery学习之路(8)- 表单验证插件-Validation

    ▓▓▓▓▓▓ 大致介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的验证方法,包括 ...

  8. jQuery Validation Engine 表单验证

    功能强大的 jQuery 表单验证插件,适用于日常的 E-mail.电话号码.网址等验证及 Ajax 验证,除自身拥有丰富的验证规则外,还可以添加自定义的验证规则. 兼容 IE 6+, Chrome, ...

  9. Laravel教程 七:表单验证 Validation

    Laravel教程 七:表单验证 Validation 此文章为原创文章,未经同意,禁止转载. Laravel Form 终于要更新这个Laravel系列教程的第七篇了,期间去写了一点其他的东西. 就 ...

  10. jquery.validation.js 表单验证

    jquery.validation.js 表单验证   官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuer ...

随机推荐

  1. mac忘记操作密码

    转载于:https://blog.csdn.net/wu110112/article/details/70312987 如果忘记mac登陆密码应该如何处理呢? 这里大家请勿着急,我来帮大家解决这个问题 ...

  2. SpringIOC和AOP原理 设计模式

    SpringIOC的特点 在接触Spring的过程中,听到最多的无非两个名词,一个是控制反转一个是依赖注入.实际这是一个意思,控制反转代表原来由程序本身去控制对象之间的依赖关系的这种格局被反转了,通过 ...

  3. CEF 右键添加开发者选项菜单项

    在项目开发过程中,有时候需要进行调试测试,然后我们可以在cef上下文菜单中添加自定义开发者工具菜单项,这样会比较方便,最后效果: 实现过程: 让自己的MyClientHandler来继承 CefCon ...

  4. Swagger2使用参考

    GitHub例子: 参考博客: https://blog.csdn.net/sanyaoxu_2/article/details/80555328 http://www.cnblogs.com/Joi ...

  5. CSS布局学习(二) - flex属性

    flex属性 定义 flex布局包括最外层的容器和内部的元素,flex属性是内部元素属性.flex属性是flex-grow, flex-shrink, flex-basis三个属性的简写 flex-g ...

  6. 使用scss为css样式自动添加浏览器前缀

    当一个浏览器实现一个新的属性.值或者选择器,而这个特征还不是处于候选推荐标准状态的时候,这属性的前面会添加一个前缀以便于它的渲染引擎识别. 浏览器使用前缀来尝试一些新属性.值和选择器,即使他们还没有最 ...

  7. 最接近的三数之和(java实现)

    题目: 给定一个包括 n 个整数的数组 nums 和 一个目标值 target.找出 nums 中的三个整数,使得它们的和与 target 最接近.返回这三个数的和.假定每组输入只存在唯一答案. 例如 ...

  8. echarts tooltip巧用

    tooltip : { trigger: 'item', triggerOn: 'click', formatter:function(params,ticket,callback){ var res ...

  9. bzoj 5068: 友好的生物

    大意: n个生物, 每个生物有k种属性, 友好度通过下式计算. , C为给定非负数组, 求友好度最大值. k比较小, 求的是最大值并且$C_i$非负, 所以可以暴力枚举正负情况去绝对值号. #incl ...

  10. windows service 2008 R2 安装net4.6环境失败,windows service 2008 R2 升级sp1问题

    一.错误 1.因为我的程序是以vs2017开发的,在windows service 2008 R2  IIS部署项目文件报出错误,因此要安装net4.6的环境. 2.windows service 2 ...