彻底弄懂angularJS表单验证

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了彻底弄懂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" />

我们使用了 ng-show指令, color:red 在邮件是 $dirty 或 $invalid 才显示:

属性描述
$dirty 表单有填写记录
$valid 字段内容合法的
$invalid 字段内容是非法的
$pristine 表单没有填写记录

 

示例(以邮箱为例+正则表达式 引入angular+bootstrap)

ng正则表达式写法:

ng-pattern=" /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/"  //邮箱验证

<body  ng-Controller="MyController">  //ng-app标在html标签上
<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="email"> 电子邮件</label>
      </div>
      <div class="col-md-6">
        <input type="email" id="email" name="email" ng-minlength="5" ng-maxlength="30" ng-pattern=" /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/" ng-model="user.email" required class="form-control" />
        <span class="glyphicon glyphicon-ok form-control-feedback"
              ng-show="myForm.email.$dirty && myForm.email.$valid"></span>

      </div>
      <div class="col-md-2">
        <span style="color:red" class=""
              ng-show="myForm.email.$dirty && myForm.email.$invalid">邮箱格式错误!</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>

<script>
  angular.module(myTest, [])
          .controller(MyController, function($scope) {
                    $scope.submitForm = function(isValid) {
                      if (!isValid) {
                        alert(验证失败);
                      }
                    };
                  }
          );
</script>
</body>

 


也可以更详尽的支出单个错误:

<div ng-show="myForm.email.$dirty && myForm.email.$error.maxlength" class="alert alert-danger help-block">
          邮箱长度不能超过30位
</div>
<div ng-show="myForm.email.$dirty && myForm.email.$error.minlength" class="alert alert-danger help-block">
          邮箱长度不能小于5位
</div>
<div ng-show="myForm.email.$dirty && myForm.email.$error.email" class="alert alert-danger help-block">
          邮箱格式不正确
</div>

 

  

 



以上是关于彻底弄懂angularJS表单验证的主要内容,如果未能解决你的问题,请参考以下文章

AngularJS入门学习笔记一

AngularJS的学习笔记

通俗易懂讲解,彻底弄懂 https 原理本质https 的过程

Go语言学习——彻底弄懂return和defer的微妙关系

彻底弄懂“PKIX path building failed”问题

AngularJS:防止验证隐藏的表单字段