Heim  >  Artikel  >  Web-Frontend  >  Detaillierte Erläuterung der AngularJS-Implementierung von form validation_AngularJS

Detaillierte Erläuterung der AngularJS-Implementierung von form validation_AngularJS

WBOY
WBOYOriginal
2016-05-16 15:26:311116Durchsuche

Beginnen Sie mit dem Erlernen der AngularJS-Formularvalidierung:

Häufig verwendete Formularvalidierungsanweisungen
1. Überprüfung der erforderlichen Felder

Unabhängig davon, ob eine Formulareingabe ausgefüllt wurde, fügen Sie einfach das erforderliche HTML5-Tag zum Eingabefeldelement hinzu:

Code kopieren Der Code lautet wie folgt:
6b51461ce3f12e597d4839573924d0fb

2. Mindestlänge

Um zu überprüfen, ob die Textlänge der Formulareingabe größer als ein bestimmter Mindestwert ist, verwenden Sie den Befehl ng-minleng= "{number}" im Eingabefeld:

Code kopieren Der Code lautet wie folgt:
f353658296dd01791fb51e2b4d7c31a5

3. Maximale Länge

Um zu überprüfen, ob die Textlänge der Formulareingabe kleiner oder gleich einem bestimmten Maximalwert ist, verwenden Sie den Befehl ng-maxlength="{number}" im Eingabefeld:

Code kopieren Der Code lautet wie folgt:
6644dd41478b0e7bbdc7561c5cfc7e9a

4. Mustervergleich

Verwenden Sie ng-pattern="/PATTERN/", um sicherzustellen, dass die Eingabe mit dem angegebenen regulären Ausdruck übereinstimmt:

Code kopieren Der Code lautet wie folgt:
58fa7513c4bf511af4bf9edb68ab6899

5. E-Mail

Um zu überprüfen, ob es sich bei dem Eingabeinhalt um eine E-Mail handelt, stellen Sie einfach den Eingabetyp wie folgt auf E-Mail ein:

Code kopieren Der Code lautet wie folgt:
8a522b61edc6c2850a67d97702bbdab7

6. Zahlen

Überprüfen Sie, ob der Eingabeinhalt eine Zahl ist, und legen Sie den Eingabetyp auf Zahl fest:

Code kopieren Der Code lautet wie folgt:
09eef5fe36886ca2e28d68766a87c875

7. URL

Überprüfen Sie, ob der Eingabeinhalt eine URL ist, und legen Sie den Eingabetyp auf URL fest:

Code kopieren Der Code lautet wie folgt:
e3bae3997f4320d19d7db0e28f7a5d65
Lassen Sie uns diese Formularvalidierungen in spezifische Implementierungen umsetzen, um sie zu testen:

在测试中我们发现,只有当表达式满足验证,才会实时进行双向绑定。同时我们也发现,效果图如下:

似乎并没有发生什么问题,但是如果我们将其移植到一个队HTML5验证不怎么好的浏览器再来测试一下【本例IE9】,问题来了,某些字段完全没得验证

其实,上面的例子,我们利用了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>

效果如下:

同时,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!#$%&'*+\/=&#63;^_`{|}~.-]+@[a-z0-9-]+(\.[a-z0-9-]+)*[;;]&#63;)+$/i;
  }
  var customValidator = function (value) {
   var validity = ngModel.$isEmpty(value) || emailsRegexp.test(value);
   ngModel.$setValidity("multipleEmail", validity);
   return validity &#63; 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>

Kod ini sangat mudah, dan kesannya adalah seperti berikut:

Kod ini sangat mudah, tetapi ia melibatkan beberapa atribut penting ngModelController
$viewValue

Sifat

$viewValue memegang rentetan sebenar yang diperlukan untuk mengemas kini paparan.

$modelValue

$modelValue dipegang oleh model data. $modelValue dan $viewValue mungkin berbeza bergantung pada sama ada saluran paip $parser beroperasi padanya.

$parsers

Nilai

$parsers ialah susunan fungsi Apabila pengguna berinteraksi dengan pengawal dan kaedah $setViewValue() dalam ngModelController dipanggil, nilai When the. pengguna berinteraksi dengan pengawal, fungsi akan dipanggil satu demi satu dalam bentuk saluran paip apabila kaedah $setViewValue() dalam ngModelController dipanggil. Nilai yang dibaca oleh ngModel daripada DOM akan dihantar ke dalam fungsi dalam $parsers dan diproses oleh parser di dalamnya. Ini adalah untuk memproses dan mengubah suai nilai.

Nota: Fungsi ngModel.$setViewValue() digunakan untuk menetapkan nilai paparan dalam skop.

Fungsi

ngModel.$set ViewValue() boleh menerima satu parameter.

nilai (rentetan): Parameter nilai ialah nilai sebenar yang ingin kami tetapkan kepada tika ngModel.

Kaedah ini akan mengemas kini $viewValue setempat pada pengawal dan kemudian menghantar nilai kepada setiap fungsi $parser (termasuk pengesah). Apabila nilai dihuraikan dan semua fungsi dalam saluran paip $parser telah dipanggil, nilai diberikan kepada atribut $modelValue dan dihantar kepada ungkapan yang disediakan oleh atribut ng-model dalam arahan. Akhir sekali, selepas semua langkah selesai, semua pendengar dalam $viewChangeListeners akan dipanggil. Ambil perhatian bahawa memanggil $setViewValue() sahaja tidak akan mencetuskan gelung ringkasan baharu, jadi jika anda ingin mengemas kini arahan, anda perlu mencetuskan ringkasan secara manual selepas menetapkan $viewValue. Kaedah $setViewValue() sesuai untuk mendengar acara tersuai dalam arahan tersuai (seperti menggunakan pemalam jQuery dengan fungsi panggil balik Kami akan mahu menetapkan $viewValue dan melaksanakan gelung ringkasan semasa panggilan balik).

$formatters

Nilai

$formatters ialah tatasusunan fungsi, di mana fungsi akan dipanggil satu demi satu dalam bentuk saluran paip apabila nilai model data berubah . Ia tidak mempunyai pengaruh pada saluran paip $parser dan digunakan untuk memformat dan menukar nilai supaya ia boleh dipaparkan dalam kawalan terikat kepada nilai ini.

$viewChangeListeners

Nilai

$viewChangeListeners ialah tatasusunan fungsi, fungsi yang akan dipanggil satu demi satu dalam bentuk saluran paip apabila nilai dalam paparan berubah. Tingkah laku yang sama boleh dicapai tanpa menggunakan $watch melalui $viewChangeListeners. Fungsi ini tidak memerlukan nilai pulangan kerana nilai pulangan diabaikan.

$error

Objek

$error menyimpan nama pengesah yang gagal pengesahan dan mesej ralat yang sepadan.

$murni

Nilai

$pristine ialah Boolean dan boleh memberitahu kami sama ada pengguna telah mengubah suai kawalan.

$kotor

Nilai

$dirty adalah bertentangan dengan $pristine dan boleh memberitahu kami sama ada pengguna telah berinteraksi dengan kawalan.

$sah

Nilai

$valid boleh memberitahu kami sama ada terdapat ralat dalam kawalan semasa. Nilai adalah palsu apabila terdapat ralat dan benar apabila tiada ralat.

$tidak sah

Nilai

$invalid boleh memberitahu kami sama ada terdapat sekurang-kurangnya satu ralat dalam kawalan semasa dan nilainya bertentangan dengan $valid.

Di atas adalah keseluruhan kandungan artikel ini, saya harap ia akan membantu semua orang dalam melaksanakan pengesahan borang AngularJS.

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn