摘要:在自定義的指令中,我們可以添加我們的驗證方法到的對象上。驗證碼在表單不合法時禁用提交按鈕提交保存成功判斷手機號是否重復驗證兩次輸入的密碼是否相同的自定義驗證當值為空時,通過驗證,因為有
Angular實現(xiàn)了大部分常用的HTML5的表單控件的類型(text, number, url, email, date, radio, checkbox),也實現(xiàn)了很多指令做為驗證(required, pattern, minlength, maxlength, min, max)。
在自定義的指令中,我們可以添加我們的驗證方法到ngModelController的$validators對象上。為了取得這個controller對象,我們需要requirengModel指令。
在$validators對象上的每個方法都接收modelValue和viewValue兩個值做為參數(shù)。在你綁定的驗證方法返回一個值(true,false)之后,Angular會在內(nèi)部調(diào)用$setValidity方法。驗證會在每一次輸入框的值改變($setViewValue被調(diào)用)或者模型的值改變。驗證發(fā)生在$parsers和$formatters成功運行之后,驗證不通過的項會做為ngModelController.$error的屬性存儲起來。
另外,在這個controller對象上,還有一個$asyncValidators對象,如果你的驗證是異步的,則需要加驗證附加在這個對象上,比如說用戶注冊時輸入手機號,我們需要在后端驗證該手機號是否已經(jīng)注冊,這個驗證方法必須return一個promise對象,然后在驗證通過時調(diào)用延遲對象的resolve,失敗時調(diào)用reject,還未完成的異步的驗證存儲在ngModelController.$pending中。
例如(注意其中的user對象,只有驗證通過了,才會將值綁定到模型上):
{{ user | json }}
"use strict"; angular.module("app", []) .directive("phone", function ($q, $http) { return { require: "ngModel", link: function (scope, ele, attrs, ctrl) { ctrl.$asyncValidators.phone = function (modelValue, viewValue) { var d = $q.defer(); $http.get("phone.json") .success(function (phoneList) { if (phoneList.indexOf(parseInt(modelValue)) >= 0) { d.reject(); } else { d.resolve(); } }); return d.promise; } } } }) .directive("username", function ($q, $http) { return { require: "ngModel", link: function (scope, ele, attrs, ctrl) { ctrl.$validators.username = function (modelValue, viewValue) { if (modelValue) { return modelValue.length > 5 ? true : false; }; return false; } } } })
[ 13758262732, 15658898520, 13628389818, 18976176895, 13518077986 ]
效果:
下面一個完整的用戶注冊的表單驗證:
html:
"use strict"; angular.module("app", []) .controller("myCtrl", function ($scope) { $scope.data = {}; $scope.save = function () { alert("保存成功!") } }) // 判斷手機號是否重復 .directive("phone", function ($q, $http) { return { require: "ngModel", link: function (scope, ele, attrs, ctrl) { ctrl.$asyncValidators.phone = function (modelValue, viewValue) { var d = $q.defer(); $http.get("phone.json") .success(function (phoneList) { if (phoneList.indexOf(parseInt(modelValue)) >= 0) { d.reject(); } else { d.resolve(); } }); return d.promise; } } } }) // 驗證兩次輸入的密碼是否相同的自定義驗證 .directive("pwdRepeat", function () { return { require: "ngModel", link: function (scope, ele, attrs, ctrl) { ctrl.$validators.pwdRepeat = function (modelValue) { // 當值為空時,通過驗證,因為有required if (ctrl.$isEmpty(modelValue)) { return true; } return modelValue === scope.data._password ? true : false; } } } })
form-group { position: relative; } .right { position: absolute; right: 10px; top: 34px; color: green"; }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/79618.html
ngVerify v1.5.6 a easy AngularJS Form Validation plugin.簡潔高效的__表單驗證插件__ See how powerful it.看看它有多強大 動態(tài)校驗 自動關(guān)聯(lián)提交按鈕 多種 tip 校驗消息提示 不只校驗 dom 元素值,還可以校驗 ngModel 數(shù)據(jù)模型 支持任意類型表單元素,甚至可以校驗非表單元素 提供 type 類型校驗?zāi)0?..
摘要:在自定義的指令中,我們可以添加我們的驗證方法到的對象上。驗證碼在表單不合法時禁用提交按鈕提交保存成功判斷手機號是否重復驗證兩次輸入的密碼是否相同的自定義驗證當值為空時,通過驗證,因為有 Angular實現(xiàn)了大部分常用的HTML5的表單控件的類型(text, number, url, email, date, radio, checkbox),也實現(xiàn)了很多指令做為驗證(required,...
摘要:在自定義的指令中,我們可以添加我們的驗證方法到的對象上。驗證碼在表單不合法時禁用提交按鈕提交保存成功判斷手機號是否重復驗證兩次輸入的密碼是否相同的自定義驗證當值為空時,通過驗證,因為有 Angular實現(xiàn)了大部分常用的HTML5的表單控件的類型(text, number, url, email, date, radio, checkbox),也實現(xiàn)了很多指令做為驗證(required,...
摘要:表單和其中的表單控件提供了驗證服務(wù),可以讓用戶在提交一般在點擊類型為的按鈕時提交表單前意識到自己有非法不符合要求,以下都將稱為非法的輸入。為了編寫一個可靠的應(yīng)用程序,服務(wù)端驗證是不可或缺的。促發(fā)條件至于自定義表單驗證,我會另寫一篇。 表單 網(wǎng)頁中用戶于服務(wù)端交互數(shù)據(jù)的表單控件有input、select、textarea,而表單是將為了達到一個目的(登錄、注冊等)各種控件整合到一起的一個...
摘要:表單和其中的表單控件提供了驗證服務(wù),可以讓用戶在提交一般在點擊類型為的按鈕時提交表單前意識到自己有非法不符合要求,以下都將稱為非法的輸入。為了編寫一個可靠的應(yīng)用程序,服務(wù)端驗證是不可或缺的。促發(fā)條件至于自定義表單驗證,我會另寫一篇。 表單 網(wǎng)頁中用戶于服務(wù)端交互數(shù)據(jù)的表單控件有input、select、textarea,而表單是將為了達到一個目的(登錄、注冊等)各種控件整合到一起的一個...
閱讀 4325·2021-10-13 09:39
閱讀 493·2021-09-06 15:02
閱讀 3236·2019-08-30 15:53
閱讀 1051·2019-08-30 13:04
閱讀 2057·2019-08-30 11:27
閱讀 2020·2019-08-26 13:51
閱讀 2105·2019-08-26 11:33
閱讀 2910·2019-08-26 10:36