亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

詳解AngularJS實現表單驗證

2024-05-06 16:26:01
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了AngularJS實現表單驗證,客戶端表單驗證是AngularJS里面最酷的功能之一。AngularJS表單驗證可以讓你從一開始就寫出一個具有交互性和可相應的現代HTML5表單,對AngularJS表單驗證感興趣的小伙伴們可以參考一下
 

開始學習AngularJS表單驗證:

常用的表單驗證指令 
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>

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

詳解AngularJS實現表單驗證

似乎并沒有發生什么問題,但是如果我們將其移植到一個隊HTML5驗證不怎么好的瀏覽器再來測試一下【本例IE9】,問題來了,某些字段完全沒得驗證

詳解AngularJS實現表單驗證

其實,上面的例子,我們利用了HTML5的驗證與ng自有的驗證進行了結合,不支持HTML5驗證,但ng自由驗證運行良好。解決方案很簡單,可以使用模式匹配的方式解決這幾種情況,也可以自定義驗證指令來復寫或者重定義驗證規則。

屏蔽瀏覽器對表單的默認驗證行為
在表單元素上添加novalidate標記即可,問題是我們怎么知道我們的表單有哪些字段是有效的,那些事非法或者無效的?ng對此也提供了非常棒的解決方案,表單的屬性可以在其所屬的$scope對象中訪問到,而我們又可以訪問$scope對象,因此JavaScript可以間接地訪問DOM中的表單屬性。借助這些屬性,我們可以對表單做出實時響應。

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

未修改過的表單

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

修改的表單

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

經過驗證的表單

布爾型屬性,它指示表單是否通過驗證。如果表單當前通過驗證,他將為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}}    $pristine 【沒修改】:{{myForm.name.$pristine }}    $dirty【修改過】:{{myForm.name.$dirty}}    $invalid【驗證失敗】:{{myForm.name.$invalid}}    $invalid【驗證成功】:{{myForm.name.$valid}}    required:{{myForm.name.$error.required}}    <br>  2.最小長度=5:{{user.minlength}}  $pristine 【沒修改】:{{myForm.minlength.$pristine }}    $dirty【修改過】:{{myForm.minlength.$dirty}}    $invalid【驗證失敗】:{{myForm.minlength.$invalid}}    $invalid【驗證成功】:{{myForm.minlength.$valid}}    $error【錯誤詳情】:{{myForm.minlength.$error}}  <br>  3.最大長度=20:{{user.maxlength}}  $pristine 【沒修改】:{{myForm.maxlength.$pristine }}    $dirty【修改過】:{{myForm.maxlength.$dirty}}    $invalid【驗證失敗】:{{myForm.maxlength.$invalid}}    $invalid【驗證成功】:{{myForm.maxlength.$valid}}    $error【錯誤詳情】:{{myForm.maxlength.$error}}  <br>  4.模式匹配:{{user.pattern}}  $pristine 【沒修改】:{{myForm.pattern.$pristine }}    $dirty【修改過】:{{myForm.pattern.$dirty}}    $invalid【驗證失敗】:{{myForm.pattern.$invalid}}    $invalid【驗證成功】:{{myForm.pattern.$valid}}    $error【錯誤詳情】:{{myForm.pattern.$error}}  <br>  5.電子郵件:{{user.email}}  $pristine 【沒修改】:{{myForm.email.$pristine }}    $dirty【修改過】:{{myForm.email.$dirty}}    $invalid【驗證失敗】:{{myForm.email.$invalid}}    $invalid【驗證成功】:{{myForm.email.$valid}}    $error【錯誤詳情】:{{myForm.email.$error}}  <br>  6.數字:{{user.age}}  $pristine 【沒修改】:{{myForm.age.$pristine }}    $dirty【修改過】:{{myForm.age.$dirty}}    $invalid【驗證失敗】:{{myForm.age.$invalid}}    $invalid【驗證成功】:{{myForm.age.$valid}}    $error【錯誤詳情】:{{myForm.age.$error}}  <br>  7.URL:{{user.url}}  $pristine 【沒修改】:{{myForm.url.$pristine }}    $dirty【修改過】:{{myForm.url.$dirty}}    $invalid【驗證失敗】:{{myForm.url.$invalid}}    $invalid【驗證成功】:{{myForm.url.$valid}}    $error【錯誤詳情】:{{myForm.url.$error}}  <br> </div> </body></html><script type="text/javascript"> angular.module('myTest', []) .controller('myController', function($scope) {  $scope.submitForm = function(isValid) {  if (!isValid) {   alert('驗證失敗');  }  }; } );</script>

效果如下:

詳解AngularJS實現表單驗證

同時,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 . 你可以私有定制化這些類來實現特定的場景應用.

但是,默認的驗證指令不一定能夠,完全滿足我們的真實應用場景,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>

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

詳解AngularJS實現表單驗證

這段代碼很簡單,但是涉及到了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相反。

以上就是本文的全部內容,希望對大家實現AngularJS表單驗證有所幫助。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品v欧美精品v日韩精品| 久久综合五月天| 精品久久久久久久久国产字幕| 欧美成人精品激情在线观看| 久久精品91久久香蕉加勒比| 国产精品久久久久久久久男| 欧美国产日韩xxxxx| 全亚洲最色的网站在线观看| 成人国产在线激情| 亚洲性夜色噜噜噜7777| 26uuu久久噜噜噜噜| 国产成人精品视频在线观看| 在线观看久久av| 96pao国产成视频永久免费| 久久中文字幕视频| 日韩欧美在线网址| 欧美黑人又粗大| 日韩av中文在线| 欧美日韩国产综合新一区| 国产精品成人免费电影| 亚洲精品乱码久久久久久按摩观| 日韩欧美亚洲国产一区| 国产视频亚洲视频| 国产免费一区二区三区在线能观看| 精品偷拍一区二区三区在线看| 狠狠躁天天躁日日躁欧美| 精品国产1区2区| 国产偷国产偷亚洲清高网站| 欧美日韩成人黄色| 一区二区福利视频| 亚洲国产精彩中文乱码av在线播放| 国产精品福利网| 亚洲天堂av图片| 国产亚洲人成a一在线v站| 日韩精品免费看| 狠狠躁夜夜躁人人爽超碰91| 日本亚洲欧美三级| 久久久久久久国产| 欧美一区二区三区精品电影| 久久久久久久久久久国产| 2019日本中文字幕| 国产精品99久久99久久久二8| 美乳少妇欧美精品| 国产精品va在线| 中文字幕精品—区二区| 中文字幕av日韩| 亚洲国产精品小视频| 精品国产一区二区三区久久狼黑人| 国产91色在线|免| 亚洲free性xxxx护士白浆| 亚洲理论片在线观看| 菠萝蜜影院一区二区免费| 岛国视频午夜一区免费在线观看| 日韩免费av片在线观看| 久久精品国产96久久久香蕉| 久久躁狠狠躁夜夜爽| 欧美性猛交99久久久久99按摩| 97精品国产97久久久久久| 97超级碰碰人国产在线观看| 91在线播放国产| 国产精品成人一区二区三区吃奶| 欧美黄色片免费观看| 欧美高清自拍一区| 国产一区二区三区在线视频| 国产一区二区三区三区在线观看| 中文字幕视频一区二区在线有码| 国产综合久久久久久| 亚洲热线99精品视频| 亚洲第一区在线| 国产91色在线免费| 亚洲黄色www网站| 日韩在线观看成人| 亚洲综合最新在线| 全亚洲最色的网站在线观看| 国产精品三级在线| 国产精品视频一区二区三区四| 日本韩国欧美精品大片卡二| 亚洲欧美精品一区二区| 国模视频一区二区三区| 久久国产天堂福利天堂| 精品夜色国产国偷在线| 日韩在线免费观看视频| 欧美黑人一级爽快片淫片高清| 国产成人a亚洲精品| 国产97人人超碰caoprom| 欧美日韩免费区域视频在线观看| 欧美放荡办公室videos4k| 在线国产精品播放| 91在线国产电影| 九九热精品在线| 高清欧美性猛交xxxx黑人猛交| www.日韩欧美| 97久久超碰福利国产精品…| 91精品久久久久| 日韩av日韩在线观看| 欧美激情在线观看| 中文字幕9999| 久久av资源网站| 亚洲小视频在线| 欧美亚洲视频一区二区| 亚洲伦理中文字幕| 成人精品视频久久久久| 91免费综合在线| 日韩电影中文字幕在线| 亚洲视频在线观看网站| 91色在线视频| 国产精品久久久久福利| 亚洲va欧美va在线观看| 国产精品无码专区在线观看| 日韩av影视综合网| 91夜夜揉人人捏人人添红杏| 色偷偷偷综合中文字幕;dd| 日韩电影中文 亚洲精品乱码| 色婷婷综合久久久久中文字幕1| 亚洲欧美日韩国产中文| 中文欧美在线视频| 综合欧美国产视频二区| 97视频在线观看视频免费视频| 久久99视频精品| 欧美亚洲激情视频| 亚洲欧美综合v| 久久久久久久亚洲精品| 成人国内精品久久久久一区| 国产日韩在线观看av| 日韩免费观看在线观看| 中文字幕av一区中文字幕天堂| 黑人精品xxx一区一二区| 1769国内精品视频在线播放| 91综合免费在线| 久久久久免费视频| 亚洲精品久久久久中文字幕欢迎你| 欧美视频免费在线| 久久综合色88| 欧美激情精品久久久久久久变态| 在线国产精品播放| 国产精品精品久久久久久| 亚洲一区二区久久久久久久| 成人国产精品免费视频| 久久精品国产亚洲| 久久精品这里热有精品| 国产欧美日韩高清| 琪琪亚洲精品午夜在线| 国产精品1区2区在线观看| 1769国内精品视频在线播放| 7777精品视频| 欧美专区中文字幕| 欧美激情精品久久久久久大尺度| 亚洲欧洲在线视频| 亚洲精品视频免费在线观看| 国产日韩精品综合网站| 亚洲自拍小视频免费观看| 亚洲精品美女久久| 国产91亚洲精品| 欧美电影第一页| …久久精品99久久香蕉国产| 欧美性在线观看| 97在线视频免费| 亚洲情综合五月天| 亚洲最大在线视频| 亚洲欧美日韩一区二区三区在线| 日韩精品视频在线观看网址| 欧美成人午夜免费视在线看片| 日韩av中文字幕在线播放| 久久久成人精品视频|