angularjs 表單驗證

来源:https://www.cnblogs.com/chaixiaozhi/archive/2018/03/04/8504434.html
-Advertisement-
Play Games

一、常用的表單驗證指令 1. 必填項驗證 某個表單輸入是否已填寫,只要在輸入欄位元素上添加HTML5標記required即可: 2. 最小長度 驗證表單輸入的文本長度是否大於某個最小值,在輸入欄位上使用指令ng-minleng= "{number}": 3. 最大長度 驗證表單輸入的文本長度是否小於 ...


一、常用的表單驗證指令 

1. 必填項驗證

某個表單輸入是否已填寫,只要在輸入欄位元素上添加HTML5標記required即可:

<input type="text" required />  

2. 最小長度

驗證表單輸入的文本長度是否大於某個最小值,在輸入欄位上使用指令ng-minleng= "{number}":

<input type="text" ng-minlength="5" /> 

3. 最大長度

驗證表單輸入的文本長度是否小於或等於某個最大值,在輸入欄位上使用指令ng-maxlength="{number}":

<input type="text" ng-maxlength="20" />

4. 模式匹配

使用ng-pattern="/PATTERN/"來確保輸入能夠匹配指定的正則表達式:

<input type="text" ng-pattern="/[a-zA-Z]/" /> 

5. 電子郵件

驗證輸入內容是否是電子郵件,只要像下麵這樣將input的類型設置為email即可:

<input type="email" name="email" ng-model="user.email" /> 

6. 數字

驗證輸入內容是否是數字,將input的類型設置為number:

<input type="number" name="age" ng-model="user.age" /> 

7. URL

 驗證輸入內容是否是URL,將input的類型設置為 url:

<input type="url" name="homepage" ng-model="user.facebook_url" />

 

 下麵我們將這些表單驗證放到具體的實現中來測試一下:

<div class="col-md-6">
        <form role="form" class="form-horizontal">
            <div class="form-group">
                <div class="col-md-4">
                    <label for="name">1.必填項</label>
                </div>
                <div class="col-md-8">
                    <input class="form-control" id="name" type="text" required ng-model='user.name' />
                </div>
            </div>
            <div class="form-group">
                <div class="col-md-4">
                    <label for="minlength">2.最小長度=5</label>
                </div>
                <div class="col-md-8">
                    <input type="text" id="minlength" ng-minlength="5" ng-model="user.minlength" class="form-control" />
                </div>
            </div>
            <div class="form-group">
                <div class="col-md-4">
                    <label for="minlength">3.最大長度=20</label>
          </div>
                <div class="col-md-8">
                    <input type="text" ng-model="user.maxlength" ng-maxlength="20" class="form-control" />
                </div>
            </div>
            <div class="form-group">
                <div class="col-md-4">
                    <label for="minlength">4. 模式匹配</label>
               </div>
                <div class="col-md-8">
                 <input type="text" id="minlength" ng-model="user.pattern" ng-pattern="/^[a-zA-Z]*\d$/" class="form-control" />
                </div>
            </div>
            <div class="form-group">
                <div class="col-md-4">
                    <label for="email">5. 電子郵件</label>
          </div>
                <div class="col-md-8">
                    <input type="email" id="email" name="email" ng-model="user.email" class="form-control" />
                </div>
            </div>
            <div class="form-group">
                <div class="col-md-4">
                    <label for="age">6. 數字</label>
          </div>
                <div class="col-md-8">
                    <input type="number" id="age" name="age" ng-model="user.age" class="form-control" />
                </div>
            </div>
            <div class="form-group">
                <div class="col-md-4">
                    <label for="url"> 7. URL</label>
          </div>
                <div class="col-md-8">
                    <input type="url" id="url" name="homepage" ng-model="user.url" class="form-control" />
                </div>
            </div>
            <div class="form-group text-center">
                <input class="btn btn-primary btn-lg" type="submit" value="提交" />
            </div>
        </form>       
    </div>
    <div class="col-md-12">
        1.必填項:{{user.name}}<br>
        2.最小長度=5:{{user.minlength}}<br>
        3.最大長度=20:{{user.maxlength}}<br>
        4.模式匹配:{{user.pattern}}<br>
        5.電子郵件:{{user.email}}<br>
        6.數字:{{user.age}}<br>
        7.URL:{{user.url}}<br>
    </div>

在測試中我們發現,只有當表達式滿足驗證,才會實時進行雙向綁定。同時我們也發現,效果圖如下:

 二、表單中控制變數

屏蔽瀏覽器對錶單的預設驗證行為

在表單元素上添加novalidate標記即可,問題是我們怎麼知道我們的表單有哪些欄位是有效的,那些事非法或者無效的?ng對此也提供了非常棒的解決方案,表單的屬性可以在其所屬的$scope對象中訪問到,而我們又可以訪問$scope對象,因此JavaScript可以間接地訪問DOM中的表單屬性。藉助這些屬性,我們可以對錶單做出實時響應。

可以使用formName.inputFieldName.property的格式訪問這些屬性。

修改的表單

布爾型屬性,當且僅當用戶實際已經修改的表單。不管表單是否通過驗證:

formName.inputFieldName.$dirty

未修改過的表單

布爾值屬性,表示用戶是否修改了表單。如果為ture,表示沒有修改過;false表示修改過:

formName.inputFieldName.$pristine;

經過驗證的表單

布爾型屬性,它指示表單是否通過驗證。如果表單當前通過驗證,他將為true:

formName.inputFieldName.$valid

未通過驗證的表單

formName.inputFieldName.$invalid

 

最後兩個屬性在用於DOM元素的顯示或隱藏時是特別有用的。同時,如果要設置特定的class時,他們也非常有用的。

錯誤

這是AngularJS提供的另外一個非常有用的屬性:$error對象。它包含當前表單的所有驗證內容,以及它們是否合法的信息。用下麵的語法訪問這個屬性

formName.inputfieldName.$error

如果驗證失敗,這個屬性的值為true;如果值為false,說明輸入欄位的值通過了驗證。

 

<!DOCTYPE html>

<html ng-app="myTest">
    <head>
        <meta name="viewport" content="width=device-width" />
        <title>Index</title>
        <link href="~/Content/css/bootstrap.min.css" rel="stylesheet" />
        <script src="~/Javascript/angular.min.js"> </script>
        <style type="text/css">
            body { padding-top: 30px; }
        </style>
    </head>
    <body  ng-Controller="MyController">
        <div class="col-md-6">
            <form role="form" name="myForm" ng-submit="submitForm(myForm.$valid)" class="form-horizontal" novalidate>
                <div class="form-group  has-feedback">
                    <div class="col-md-4">
                        <label for="name">1.必填項</label>
                    </div>
                    <div class="col-md-8">
                        <input class="form-control" id="name" name="name" type="text" required ng-model='user.name' />
                        <span class="glyphicon glyphicon-ok form-control-feedback"
                              ng-show="myForm.name.$dirty && myForm.name.$valid"></span>
                    </div>
                </div>
                <div class="form-group  has-feedback">
                    <div class="col-md-4">
                        <label for="minlength">2.最小長度=5</label>
                    </div>
                    <div class="col-md-8">
                        <input type="text" id="minlength" name="minlength" ng-minlength="5" ng-model="user.minlength" class="form-control" />
                        <span class="glyphicon glyphicon-ok form-control-feedback"
                              ng-show="myForm.minlength.$dirty && myForm.minlength.$valid"></span>
                    </div>
                </div>
                <div class="form-group  has-feedback">
                    <div class="col-md-4">
                        <label for="maxlength">3.最大長度=20</label>
                    </div>
                    <div class="col-md-8">
                        <input type="text" id="maxlength" name="maxlength" ng-model="user.maxlength" ng-maxlength="20" class="form-control" />
                        <span class="glyphicon glyphicon-ok form-control-feedback"
                              ng-show="myForm.maxlength.$dirty && myForm.maxlength.$valid"></span>
                    </div>
                </div>
                <div class="form-group  has-feedback">
                    <div class="col-md-4">
                        <label for="pattern">4. 模式匹配</label>
                    </div>
                    <div class="col-md-8">
                        <input type="text" id="pattern" name="pattern" ng-model="user.pattern" ng-pattern="/^[a-zA-Z]*\d$/" class="form-control" />
                        <span class="glyphicon glyphicon-ok form-control-feedback"
                              ng-show="myForm.pattern.$dirty && myForm.pattern.$valid"></span>
                    </div>
                </div>
                <div class="form-group  has-feedback">
                    <div class="col-md-4">
                        <label for="email">5. 電子郵件</label>
                    </div>
                    <div class="col-md-8">
                        <input type="email" id="email" name="email" ng-model="user.email" class="form-control" />
                        <span class="glyphicon glyphicon-ok form-control-feedback"
                              ng-show="myForm.email.$dirty && myForm.email.$valid"></span>
                    </div>
                </div>
                <div class="form-group  has-feedback">
                    <div class="col-md-4">
                        <label for="age">6. 數字</label>
                    </div>
                    <div class="col-md-8">
                        <input type="number" id="age" name="age" ng-model="user.age" class="form-control" />

                        <span class="glyphicon glyphicon-ok form-control-feedback"
                              ng-show="myForm.age.$dirty && myForm.age.$valid"></span>
                    </div>
                </div>
                <div class="form-group  has-feedback">
                    <div class="col-md-4">
                        <label for="url"> 7. URL</label>
                    </div>
                    <div class="col-md-8">
                        <input type="url" id="url" name="url" ng-model="user.url" class="form-control" />
                        <span class="glyphicon glyphicon-ok form-control-feedback"
                              ng-show="myForm.url.$dirty && myForm.url.$valid"></span>
                    </div>
                </div>
                <div class="form-group  text-center">
                    <input class="btn btn-primary btn-lg" ng-disabled="myForm.$invalid" type="submit" value="提交" />
                </div>
            </form>       
        </div>
        <div class="col-md-12">
            1.必填項:{{user.name}}&nbsp;&nbsp;
            $pristine 【沒修改】:{{myForm.name.$pristine }}&nbsp;&nbsp;
            $dirty【修改過】:{{myForm.name.$dirty}}&nbsp;&nbsp;
            $invalid【驗證失敗】:{{myForm.name.$invalid}}&nbsp;&nbsp;
            $invalid【驗證成功】:{{myForm.name.$valid}}&nbsp;&nbsp;
            required:{{myForm.name.$error.required}}&nbsp;&nbsp;
            <br>
            2.最小長度=5:{{user.minlength}}
            $pristine 【沒修改】:{{myForm.minlength.$pristine }}&nbsp;&nbsp;
            $dirty【修改過】:{{myForm.minlength.$dirty}}&nbsp;&nbsp;
            $invalid【驗證失敗】:{{myForm.minlength.$invalid}}&nbsp;&nbsp;
            $invalid【驗證成功】:{{myForm.minlength.$valid}}&nbsp;&nbsp;
            $error【錯誤詳情】:{{myForm.minlength.$error}}&nbsp;&nbsp;<br>
            3.最大長度=20:{{user.maxlength}}
            $pristine 【沒修改】:{{myForm.maxlength.$pristine }}&nbsp;&nbsp;
            $dirty【修改過】:{{myForm.maxlength.$dirty}}&nbsp;&nbsp;
            $invalid【驗證失敗】:{{myForm.maxlength.$invalid}}&nbsp;&nbsp;
            $invalid【驗證成功】:{{myForm.maxlength.$valid}}&nbsp;&nbsp;
            $error【錯誤詳情】:{{myForm.maxlength.$error}}&nbsp;&nbsp;<br>
            4.模式匹配:{{user.pattern}}
            $pristine 【沒修改】:{{myForm.pattern.$pristine }}&nbsp;&nbsp;
            $dirty【修改過】:{{myForm.pattern.$dirty}}&nbsp;&nbsp;
            $invalid【驗證失敗】:{{myForm.pattern.$invalid}}&nbsp;&nbsp;
            $invalid【驗證成功】:{{myForm.pattern.$valid}}&nbsp;&nbsp;
            $error【錯誤詳情】:{{myForm.pattern.$error}}&nbsp;&nbsp;<br>
            5.電子郵件:{{user.email}}
            $pristine 【沒修改】:{{myForm.email.$pristine }}&nbsp;&nbsp;
            $dirty【修改過】:{{myForm.email.$dirty}}&nbsp;&nbsp;
            $invalid【驗證失敗】:{{myForm.email.$invalid}}&nbsp;&nbsp;
            $invalid【驗證成功】:{{myForm.email.$valid}}&nbsp;&nbsp;
            $error【錯誤詳情】:{{myForm.email.$error}}&nbsp;&nbsp;<br>
            6.數字:{{user.age}}
            $pristine 【沒修改】:{{myForm.age.$pristine }}&nbsp;&nbsp;
            $dirty【修改過】:{{myForm.age.$dirty}}&nbsp;&nbsp;
            $invalid【驗證失敗】:{{myForm.age.$invalid}}&nbsp;&nbsp;
            $invalid【驗證成功】:{{myForm.age.$valid}}&nbsp;&nbsp;
            $error【錯誤詳情】:{{myForm.age.$error}}&nbsp;&nbsp;<br>
            7.URL:{{user.url}}
            $pristine 【沒修改】:{{myForm.url.$pristine }}&nbsp;&nbsp;
            $dirty【修改過】:{{myForm.url.$dirty}}&nbsp;&nbsp;
            $invalid【驗證失敗】:{{myForm.url.$invalid}}&nbsp;&nbsp;
            $invalid【驗證成功】:{{myForm.url.$valid}}&nbsp;&nbsp;
            $error【錯誤詳情】:{{myForm.url.$error}}&nbsp;&nbsp;<br>
        </div>
    </body>
</html>
<script type="text/javascript">
    angular.module('myTest', [])
        .controller('myController', function($scope) {
            $scope.submitForm = function(isValid) {
                if (!isValid) {
                    alert('驗證失敗');
                }
            };
        }
        );
</script>

效果如下:

 

三、一些有用的CSS樣式

同時,ng針對這幾種驗證指令,針對性的設置了一些css樣式

它們包括:

複製代碼
.ng-valid         {  }
.ng-invalid     {  }
.ng-pristine     {  }
.ng-dirty         {  }
/* really specific css rules applied by angular */
.ng-invalid-required         {  }
.ng-invalid-minlength         {  }
.ng-valid-max-length         {  }
複製代碼

它們對應著表單輸入欄位的特定狀態。
例如當某個欄位中的輸入非法時,.ng-invlid類會被添加到這個欄位上。 你可以編輯自己喜歡的CSS . 你可以私有定製化這些類來實現特定的場景應用.

    input.ng-invalid{
        border: 1px solid red;
    }

 

四、自定義驗證

 但是,預設的驗證指令不一定能夠,完全滿足我們的真實應用場景,ng同樣提供的自定義驗證指令的功能。

首先我們來看一個簡單的例子:

angular.module("myTest", [])
  .directive('multipleEmail', [function () {
      return {
          require: "ngModel",
          link: function (scope, element, attr, ngModel) {
              if (ngModel) {
                  var emailsRegexp = /^([a-z0-9!#$%&'*+\/=?^_`{|}~.-]+@[a-z0-9-]+(\.[a-z0-9-]+)*[;;]?)+$/i;
              }
              var customValidator = function (value) {
                  var validity = ngModel.$isEmpty(value) || emailsRegexp.test(value);
                  ngModel.$setValidity("multipleEmail", validity);
                  return validity ? value : undefined;
              };
              ngModel.$formatters.push(customValidator);
              ngModel.$parsers.push(customValidator);
          }
      };
  }])

頁面Html部分代碼如下:

 <form class="form-horizontal" role="form" id="custom_form" name="custom_form" novalidate>
            <div class="form-group">
                <label class="col-sm-2 control-label">多個email</label>

                <div class="col-sm-10">
                    <input multiple-email name="user_email" ng-model="user.email" required class="form-control" placeholder="自定義驗證,多個郵箱地址,以“;”或者“;”分割" />
                    驗證通過:{{custom_form.user_email.$valid}}
                </div>
            </div>
            <div class="form-group  text-center">
                <input class="btn btn-primary btn-lg" ng-disabled="custom_form.$invalid" type="submit" value="提交" />
            </div>
        </form>

代碼非常的簡單,實現的效果如下所示:

這段代碼很簡單,但是涉及到了ngModelController的幾個重要的屬性

$viewValue

$viewValue屬性保存著更新視圖所需的實際字元串。

$modelValue

$modelValue由數據模型持有。$modelValue和$viewValue可能是不同的,取決於$parser流水線是否對其進行了操作。

$parsers 

$parsers的值是一個由函數組成的數組,當用戶同控制器進行交互,並且ngModelController中的$setViewValue()方法被調用時,其中的函數在當用戶同控制器進行交互,並且ngModelController中的$setViewValue()方法被調會以流水線的形式被逐一調用。ngModel從DOM中讀取的值會被傳入$parsers中的函數,並依次被其中的解析器處理。這是為了對值進行處理和修飾。

備註:ngModel.$setViewValue()函數用於設置作用域中的視圖值。

ngModel.$set ViewValue()函數可以接受一個參數。

value(字元串):value參數是我們想要賦值給ngModel實例的實際值。

這個方法會更新控制器上本地的$viewValue,然後將值傳遞給每一個$parser函數(包括驗證器)。當值被解析,且$parser流水線中所有的函數都調用完成後,值會被賦給$modelValue屬性,並且傳遞給指令中ng-model屬性提供的表達式。最後,所有步驟都完成後,$viewChangeListeners中所有的監聽器都會被調用。註意,單獨調用$setViewValue()不會喚起一個新的digest迴圈,因此如果想更新指令,需要在設置$viewValue後手動觸發digest。$setViewValue()方法適合於在自定義指令中監聽自定義事件(比如使用具有回調函數的jQuery插件),我們會希望在回調時設置$viewValue並執行digest迴圈。

$formatters

$formatters的值是一個由函數組成的數組,其中的函數會以流水線的形式在數據模型的值發生變化時被逐一調用。它和$parser流水線互不影響,用來對值進行格式化和轉換,以便在綁定了這個值的控制項中顯示。

 $viewChangeListeners

$viewChangeListeners的值是一個由函數組成的數組,其中的函數會以流水線的形式在視圖中的值發生變化時被逐一調用。通過$viewChangeListeners,可以在無需使用$watch的情況下實現類似的行為。由於返回值會被忽略,因此這些函數不需要返回值。

 $error

$error對象中保存著沒有通過驗證的驗證器名稱以及對應的錯誤信息。

 $pristine

$pristine的值是布爾型的,可以告訴我們用戶是否對控制項進行了修改。

 $dirty

$dirty的值和$pristine相反,可以告訴我們用戶是否和控制項進行過交互。

$valid

$valid值可以告訴我們當前的控制項中是否有錯誤。當有錯誤時值為false,沒有錯誤時值為true。

$invalid

$invalid值可以告訴我們當前控制項中是否存在至少一個錯誤,它的值和$valid相反。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 高度坍塌:如果一個沒有設置高度div里的元素都是浮動元素,這個時候就可能產生高度坍塌,因為div的高度都是普通元素撐起來的,div里的元素浮動之後,元素就會脫離文檔流,所以父級的div高度就可能為零,解決辦法,使用after偽元素: ...
  • 素材要求: 圖片文件為9張正方形圖片,否則容易讓圖片變形,圖片格式任意。還需要導入move.js框架。 新手練習,多多包涵。 ...
  • HTML 不是編程語言,它是一種標記語言 HTML 中常見的幾個名詞是 元素、 標簽(開始標簽和結束標簽)、 屬性、 元素內容 這篇文章將要介紹的是 HTML 元素 HTLM 元素 元素的概念 例子: 運行結果為: 點擊跳轉到百度 上面是一個超鏈接的例子,點擊上面的文字 “點擊跳轉到百度”,就可以跳 ...
  • 如何做出漂亮的頁面: 1、 多寫頁面,多改。 2、 多寫頁面,多改。 3、 多寫頁面,多改。 大致的思想步驟: 寫頁面的時候先規劃好大致的分塊,無論是用定位或者浮動,首先要確定要應用的場景,使用完浮動後一定記得清楚浮動,使用定位時要清楚其他盒子會完全忽視這個定位的盒子,如果兩個盒子都是定位並且重疊, ...
  • **重新定義微信小程式的開發** >官網:[https://qiu8310.github.io/minapp/](https://qiu8310.github.io/minapp/) >作者:[Mora](https://github.com/qiu8310) # minapp **重新定義... ...
  • 單例模式是javascript中最簡單也是最常用的模式之一。這種模式涉及到一個單一的類,該類負責創建自己的對象,同時確保只有單個對象被創建。這個類提供了一種訪問其唯一的對象的方式,可以直接訪問,不需要實例化該類的對象。 單例模式的特點: 1、單例類只能有一個實例。 2、單例類必須自己創建自... ...
  • 源代碼: <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script type="text/javascript"> ~(function(){ var o = $({}); $.jianting = fu ...
  • 所需前置知識: HTML、CSS、JS、Vue、ES6、Npm、Webpack、Node、Express、Mongodb 項目整體架構: IDE:webstorm; 項目建立過程(cmd常用命令行指令): node的安裝 下載連接:https://nodejs.org/en/ npm的安裝 npm ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...