Angular2 自定義validators的實(shí)現(xiàn)方法
angular 當(dāng)需要form表單需要驗(yàn)證時(shí),angular自帶了許多校驗(yàn)器,但是很多時(shí)候自帶的無(wú)法滿足業(yè)務(wù)需求,這時(shí)候就需要自定義的校驗(yàn)器
定義一個(gè)validator
定義validator 需要實(shí)現(xiàn) ValidatorFn 接口
源碼:
export interface ValidatorFn { (c: AbstractControl): ValidationErrors | null; }
接收一個(gè) AbstractControl 返回 ValidationErrors 或者null
ValidationErrors 源碼
export declare type ValidationErrors = { [key: string]: any; };
這其實(shí)就是返回一個(gè) key value 類型的對(duì)象,這個(gè)對(duì)象會(huì)在驗(yàn)證信息不通過(guò)的時(shí)候賦值給 formControl.errors
寫(xiě)好的Validator 需要在創(chuàng)建FormControl作為參數(shù)傳入
FormControl 的構(gòu)造器源碼
export declare class FormControl extends AbstractControl { constructor(formState?: any, validator?: ValidatorFn | ValidatorFn[] | null, asyncValidator?: AsyncValidatorFn | AsyncValidatorFn[] | null);
下面是個(gè)簡(jiǎn)單的例子(校驗(yàn)郵箱地址):
定義一個(gè)返回 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: '請(qǐng)輸入正確的郵箱地址' }; } return {}; ④ }; }
① 方法返回 ValidatorFn 的實(shí)例
② 判斷是否符合郵箱正則表達(dá)式
③ 如果不符合 返回一個(gè) ValidationErrors 對(duì)象,errMsg 作為錯(cuò)誤信息輸出 (這里也可以再加一個(gè) 布爾型的作為判斷)
④ 如果校驗(yàn)成功返回一個(gè)空的對(duì)象
傳入校驗(yàn)器
email = new FormControl('', email())
模板:
<p *ngIf = "!email.valid && email.touched">{{email.errors.errMsg}}</p>
當(dāng)郵箱格式不正確時(shí) 這里就會(huì)顯示 ‘請(qǐng)輸入正確的郵箱地址'
至此一個(gè)簡(jiǎn)單的校驗(yàn)器就完成了。
如果想比較2個(gè)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: '請(qǐng)輸入相同郵箱地址' }; } return {}; }; }
① 只需要在這里傳入另一個(gè)需要做對(duì)比的 formControl 即可
email = new FormControl('', email()) email2 = new FormControl('', email(email))
以上所述是小編給大家介紹的Angular2 自定義validators的實(shí)現(xiàn)方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Spring Boot+AngularJS+BootStrap實(shí)現(xiàn)進(jìn)度條示例代碼
- AngularJS實(shí)現(xiàn)tab選項(xiàng)卡的方法詳解
- AngularJS實(shí)現(xiàn)單一頁(yè)面內(nèi)設(shè)置跳轉(zhuǎn)路由的方法
- angular過(guò)濾器實(shí)現(xiàn)排序功能
- angularjs+bootstrap實(shí)現(xiàn)自定義分頁(yè)的實(shí)例代碼
- AngularJS實(shí)現(xiàn)元素顯示和隱藏的幾個(gè)案例
- AngularJS實(shí)現(xiàn)表單驗(yàn)證
- 在AngularJS應(yīng)用中實(shí)現(xiàn)一些動(dòng)畫(huà)效果的代碼
- AngularJS實(shí)現(xiàn)全選反選功能
- 用AngularJS的指令實(shí)現(xiàn)tabs切換效果
- 實(shí)例詳解AngularJS實(shí)現(xiàn)無(wú)限級(jí)聯(lián)動(dòng)菜單
- AngularJS實(shí)現(xiàn)進(jìn)度條功能示例
相關(guān)文章
使用 Github Actions 自動(dòng)部署 Angular 應(yīng)用到 Github Pages的方法
這篇文章主要介紹了使用 Github Actions 自動(dòng)部署 Angular 應(yīng)用到 Github Pages,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07Angular2 父子組件數(shù)據(jù)通信實(shí)例
這篇文章主要介紹了Angular2 父子組件數(shù)據(jù)通信實(shí)例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06angularjs實(shí)現(xiàn)分頁(yè)和搜索功能
這篇文章主要介紹了angularjs實(shí)現(xiàn)分頁(yè)和搜索功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01angularJS自定義directive之帶參方法傳遞詳解
今天小編就為大家分享一篇angularJS自定義directive之帶參方法傳遞詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10AngularJS中的過(guò)濾器filter用法完全解析
這篇文章主要介紹了AngularJS中的過(guò)濾器filter用法,包括Angular中一些常用的自帶的過(guò)濾器的列舉以及自定義filter的方法,需要的朋友可以參考下2016-04-04Angular2實(shí)現(xiàn)的秒表及改良版示例
這篇文章主要介紹了Angular2實(shí)現(xiàn)的秒表及改良版,結(jié)合實(shí)例形式分析 Angular2實(shí)現(xiàn)秒表功能的原理、操作技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下2019-05-05Angular.js項(xiàng)目中使用gulp實(shí)現(xiàn)自動(dòng)化構(gòu)建以及壓縮打包詳解
基于流的前端自動(dòng)化構(gòu)建工具,利用gulp可以提高前端開(kāi)發(fā)效率,特別是在前后端分離的項(xiàng)目中。下面這篇文章主要給大家介紹了關(guān)于在Angular.js項(xiàng)目中使用gulp實(shí)現(xiàn)自動(dòng)化構(gòu)建以及壓縮打包的相關(guān)資料,需要的朋友可以參考下。2017-07-07Angular-UI Bootstrap組件實(shí)現(xiàn)警報(bào)功能
這篇文章主要介紹了Angular-UI Bootstrap組件實(shí)現(xiàn)警報(bào)功能,對(duì)Angular.js services的學(xué)習(xí)有所幫助,需要的朋友可以參考下2018-07-07