Angular2 自定义validators的实现方法


Posted in Javascript onJuly 05, 2017

angular 当需要form表单需要验证时,angular自带了许多校验器,但是很多时候自带的无法满足业务需求,这时候就需要自定义的校验器

定义一个validator

定义validator 需要实现 ValidatorFn 接口

源码:

export interface ValidatorFn {
  (c: AbstractControl): ValidationErrors | null;
}

接收一个 AbstractControl 返回 ValidationErrors 或者null

ValidationErrors 源码

export declare type ValidationErrors = {
  [key: string]: any;
};

这其实就是返回一个 key value 类型的对象,这个对象会在验证信息不通过的时候赋值给 formControl.errors

写好的Validator 需要在创建FormControl作为参数传入

FormControl 的构造器源码

export declare class FormControl extends AbstractControl {
  constructor(formState?: any, validator?: ValidatorFn | ValidatorFn[] | null, asyncValidator?: AsyncValidatorFn | AsyncValidatorFn[] | null);

下面是个简单的例子(校验邮箱地址):

定义一个返回 ValidatorFn 接口的方法

static EMAIL_REG = new RegExp('\\w[-\\w.+]*@([A-Za-z0-9][-A-Za-z0-9]+\.)+[A-Za-z]{2,14}');
static email(): ValidatorFn {
  return (control: AbstractControl): { [key: string]: any } => { ①
   if (!EMAIL_REG.test(control.value)) { ②
    return { ③
     errMsg: '请输入正确的邮箱地址'
    };
   }
   return {}; ④
  };
 }

① 方法返回 ValidatorFn 的实例

② 判断是否符合邮箱正则表达式

③ 如果不符合 返回一个 ValidationErrors 对象,errMsg 作为错误信息输出 (这里也可以再加一个 布尔型的作为判断)

④ 如果校验成功返回一个空的对象

传入校验器

email = new FormControl('', email())

模板:

<p *ngIf = "!email.valid && email.touched">{{email.errors.errMsg}}</p>

当邮箱格式不正确时 这里就会显示 ‘请输入正确的邮箱地址'

至此一个简单的校验器就完成了。

如果想比较2个form的值是否相等的话只需要做一些小的改变

static EMAIL_REG = new RegExp('\\w[-\\w.+]*@([A-Za-z0-9][-A-Za-z0-9]+\.)+[A-Za-z]{2,14}');
static email(emailForm: FormControl): ValidatorFn { ①
  return (control: AbstractControl): { [key: string]: any } => { 
   if (emailForm.value !== control.value ) { 
    return { 
     errMsg: '请输入相同邮箱地址'
    };
   }
   return {}; 
  };
 }

① 只需要在这里传入另一个需要做对比的 formControl 即可

email = new FormControl('', email())
email2 = new FormControl('', email(email))

以上所述是小编给大家介绍的Angular2 自定义validators的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JQuery从头学起第三讲
Jul 06 Javascript
基于mootools 1.3框架下的图片滑动效果代码
Apr 22 Javascript
jquery实现表单验证并阻止非法提交
Jul 09 Javascript
jquery实现清新实用的网页菜单效果
Aug 28 Javascript
jQuery实现获取table表格第一列值的方法
Mar 01 Javascript
js获取当前日期时间及其它日期操作汇总
Mar 08 Javascript
JS框架之vue.js(深入三:组件1)
Sep 29 Javascript
微信小程序 详解Page中data数据操作和函数调用
Jan 12 Javascript
微信小程序实现带刻度尺滑块功能
Mar 29 Javascript
JavaScript ES6中const、let与var的对比详解
Jun 18 Javascript
JS+H5 Canvas实现时钟效果
Jul 20 Javascript
js对象数组和对象的使用实例详解
Aug 27 Javascript
js获取元素的偏移量offset简单方法(必看)
Jul 05 #Javascript
使用angular帮你实现拖拽的示例
Jul 05 #Javascript
使用JavaScript根据图片获取条形码的方法
Jul 04 #Javascript
jquery拖动改变div大小
Jul 04 #jQuery
JavaScript无操作后屏保功能的实现方法
Jul 04 #Javascript
JS中type=&quot;button&quot;和type=&quot;submit&quot;的区别
Jul 04 #Javascript
5分钟打造简易高效的webpack常用配置
Jul 04 #Javascript
You might like
PHP4 与 MySQL 数据库操作函数详解
2006/10/09 PHP
php 处理png图片白色背景色改为透明色的实例代码
2018/12/10 PHP
JavaScript 类似flash效果的立体图片浏览器
2010/02/08 Javascript
jQuery源码分析-02正则表达式 RegExp 常用正则表达式
2011/11/14 Javascript
js实现无需数据库的县级以上联动行政区域下拉控件
2013/08/14 Javascript
jQuery取得select选择的文本与值的示例
2013/12/09 Javascript
JavaScript 异常处理 详解
2015/02/06 Javascript
浅析2种JavaScript继承方式
2015/12/04 Javascript
深入理解jQuery()方法的构建原理
2016/12/05 Javascript
jquery uploadify隐藏上传进度的实现方法
2017/02/06 Javascript
JavaScript实现开关等效果
2017/09/08 Javascript
vue的一个分页组件的示例代码
2017/12/25 Javascript
JS前端知识点总结之页面加载事件,数组操作,DOM节点操作,循环和分支
2019/07/04 Javascript
使用next.js开发网址缩短服务的方法
2020/06/17 Javascript
从零开始用webpack构建一个vue3.0项目工程的实现
2020/09/24 Javascript
Python中for循环和while循环的基本使用方法
2015/08/21 Python
Python读取视频的两种方法(imageio和cv2)
2018/04/15 Python
scrapy-redis的安装部署步骤讲解
2019/02/27 Python
使用virtualenv创建Python环境及PyQT5环境配置的方法
2019/09/10 Python
html5使用canvas压缩图片的示例代码
2018/09/11 HTML / CSS
在html页面中取得session中的值的方法
2020/08/11 HTML / CSS
美国最大的宠物药店:1-800-PetMeds
2016/10/02 全球购物
Feelunique中文官网:欧洲最大化妆品零售电商
2020/07/10 全球购物
造型师求职自荐信
2013/09/27 职场文书
医学实习生自我鉴定
2013/12/12 职场文书
优秀毕业生自我鉴定
2014/01/19 职场文书
一年级学生期末评语
2014/04/21 职场文书
三年级学生评语
2014/04/23 职场文书
活动总结书
2014/05/08 职场文书
求职意向书
2014/07/29 职场文书
教师党员个人剖析材料
2014/09/29 职场文书
煤矿安全生产工作总结
2015/08/13 职场文书
会计做账心得体会
2016/01/22 职场文书
高中信息技术教学反思
2016/02/16 职场文书
Python办公自动化之Excel(中)
2021/05/24 Python
Win11如何查看显卡型号 Win11查看显卡型号的方法
2022/08/14 数码科技