Angular2 自定义表单验证器的实现方法
废话
最近由于项目上需要用到表单验证,前面直接通过 (input) 事件进行数据检查,不好和自带的验证器统一,而且也不正统。于是打算研究一下自定义验证器,网上类似的文章很多,自己在实现的过程中还是遇到了一些问题。于是还是啰嗦的自己写一篇文章。
正文
这里有官方文档验证响应式表单,用户的视觉提示,自定义验证器,这篇文章是根据这些文档所来(前面两者就不再赘述比较简单,也说的比较清楚)
Angular支持的内置validate属性
- required- 设置表单控件值是非空的
- email - 设置表单控件的格式是email
- minlength - 设置表单控件值的最小长度
- maxlength - 设置表单控件长度的最大值
- pattern - 设置表单控件的值需匹配 pattern 对应的模式
通过表单控件的.valid判断验证结果,其结果状态
- valid - 有效
- invalid - 无效
- pristine - 表单值未改变
- dirty - 表单值已改变
- touched - 表单控件已被访问过
- untouched- 表单控件未被访问过
我们经常会遇到如下场景,表单验证(样式比较丑陋请忽略)
现在我们要实现 url 验证,可以直接通过 正则表达式来匹配,这样的话,直接用 Angular 自带的验证器即可,如果要兼容大写呢?我们就不能简单的直接使用正则来匹配了,我们需要在判断之前进行一次转换,把内容全部转换成小写,才能进行正则判断。
这里我们 新建一个 ValidatorBase 类来存放所有的验证,并且新建一个 静态方法 urlValidator(input:FormControl) 来对数据进行 url 验证。具体方法如下
import { FormControl } from '@angular/forms'; import { Injectable } from '@angular/core' export class ValidateBase{ public static urlValidator(input: FormControl){ let validateString = "(https?://|WWW||ftp://|file://)[-A-Za-z0-9+&@#/%?=~_|!:,.;]+[.]+[-A-Za-z0-9+&@#/%=~_|]"; console.log(input.value); //set value let v = input.value; if(v!=undefined&&v!="") { if(v.toLowerCase().match(validateString)) { return null; } else{ return { isUrl:true } } } return null; } }
注意
这里当匹配成功(即验证成功是需要返回 null 的,不能返回 {isUrl:false},失败是返回的{isUrl:true},不是返回 {isUrl:false}),这样才会让表单验证的值为正确的表现。
这里{isUrl:true} 中的 isUrl,即为传入的 FormControl 的.hasError()中的参数值。
调用页面
<form [formGroup]="detailForm" (ngSubmit)="submit()"> <div> <label for="LinkedURL">LinkedURL:</label> <input type="LinkedURL" name="LinkedURL" id="LinkedURL" [formControl]="LinkedURL"> <div class="col-xs-4 col-sm-4" [style.color]="(LinkedURL.touched&&LinkedURL.valid==false)?'#d16e6c':'green'" [hidden]="LinkedURL.untouched"> <div [hidden]="!LinkedURL.hasError('maxlength')">LinkedURL can not be greater than 250 characters.</div> <div [hidden]="!LinkedURL.hasError('isUrl')">LinkedURL is not an url.</div> <div [hidden]="!LinkedURL.hasError('required')">Required field.</div> <!--Suess!--> <div [style.color]="'green'" [hidden]="!LinkedURL.valid">Validate suess!</div> </div> </div> <button type="submit" [disabled]="!detailForm.valid">Log In</button> </form>
调用页面对应 ts
import { ValidateBase } from './../../Validators/Validator.base'; import { Component, OnInit } from '@angular/core'; import { FormGroup, FormBuilder, FormControl, Validators } from '@angular/forms'; @Component({ selector: 'validate-ponent', templateUrl: 'validate.ponent.html' }) export class SweepstakesDetailComponent implements OnInit { private detailForm: FormGroup; private LinkedURL: FormControl; ngOnInit(): void { this.validateForm(); } private validateForm(){ this.LinkedURL = new FormControl('',[ Validators.required, Validators.maxLength(250), ValidateBase.urlValidator ]); //form this.detailForm = this.formBuilder.group({ LinkedURL:this.LinkedURL, }); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程