成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

AngularJS自定義表單驗證

xingpingz / 1098人閱讀

摘要:在自定義的指令中,我們可以添加我們的驗證方法到的對象上。驗證碼在表單不合法時禁用提交按鈕提交保存成功判斷手機號是否重復驗證兩次輸入的密碼是否相同的自定義驗證當值為空時,通過驗證,因為有

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

相關(guān)文章

  • ngVerify - 更高效的 AngularJS 表單驗證

    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?..

    shiina 評論0 收藏0
  • AngularJS定義表單驗證

    摘要:在自定義的指令中,我們可以添加我們的驗證方法到的對象上。驗證碼在表單不合法時禁用提交按鈕提交保存成功判斷手機號是否重復驗證兩次輸入的密碼是否相同的自定義驗證當值為空時,通過驗證,因為有 Angular實現(xiàn)了大部分常用的HTML5的表單控件的類型(text, number, url, email, date, radio, checkbox),也實現(xiàn)了很多指令做為驗證(required,...

    gaomysion 評論0 收藏0
  • AngularJS定義表單驗證

    摘要:在自定義的指令中,我們可以添加我們的驗證方法到的對象上。驗證碼在表單不合法時禁用提交按鈕提交保存成功判斷手機號是否重復驗證兩次輸入的密碼是否相同的自定義驗證當值為空時,通過驗證,因為有 Angular實現(xiàn)了大部分常用的HTML5的表單控件的類型(text, number, url, email, date, radio, checkbox),也實現(xiàn)了很多指令做為驗證(required,...

    cocopeak 評論0 收藏0
  • AngularJS表單驗證

    摘要:表單和其中的表單控件提供了驗證服務(wù),可以讓用戶在提交一般在點擊類型為的按鈕時提交表單前意識到自己有非法不符合要求,以下都將稱為非法的輸入。為了編寫一個可靠的應(yīng)用程序,服務(wù)端驗證是不可或缺的。促發(fā)條件至于自定義表單驗證,我會另寫一篇。 表單 網(wǎng)頁中用戶于服務(wù)端交互數(shù)據(jù)的表單控件有input、select、textarea,而表單是將為了達到一個目的(登錄、注冊等)各種控件整合到一起的一個...

    shenhualong 評論0 收藏0
  • AngularJS表單驗證

    摘要:表單和其中的表單控件提供了驗證服務(wù),可以讓用戶在提交一般在點擊類型為的按鈕時提交表單前意識到自己有非法不符合要求,以下都將稱為非法的輸入。為了編寫一個可靠的應(yīng)用程序,服務(wù)端驗證是不可或缺的。促發(fā)條件至于自定義表單驗證,我會另寫一篇。 表單 網(wǎng)頁中用戶于服務(wù)端交互數(shù)據(jù)的表單控件有input、select、textarea,而表單是將為了達到一個目的(登錄、注冊等)各種控件整合到一起的一個...

    zorpan 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<