常用的表单验证指令 

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>

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

jQuery 1

似并无来啊问题,不过若我们拿其移植到一个批HTML5证不怎么好的浏览器还来测试一下【本例IE9】,问题来了,某些字段完全没有得验证

jQuery 2

事实上,上边的事例,我们运用了HTML5的表明和ng自有的征举行了整合,不匡助HTML5证实,但ng自由验证运行非凡。解决方案特别粗略,可以以形式匹配的办法缓解当时三种植状态,也得起定义表明指令来复写或者重定义验证规则。

遮掩浏览器对表单的默认验证行为

当表单元素上加上novalidate标记即可,问题是咱怎么了解咱们的表单有怎样字段是行之有效之,这么些从事非法或无效的?ng对这也供了生棒的解决方案,表单的性质可以于那所属的$scope对象中做客到,而大家同时美观$scope对象,由此JavaScript可以直接地访问DOM中的表单属性。借助那么些性,我们好针对表单做出实时响应。

好使formName.inputField(Field)Name.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' />

                    </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" />

                    </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" />

                    </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" />

                    </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" />

                    </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" />


                    </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" />

                    </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>

 

功效如下:

jQuery 3

而,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>

代码异常之简,实现的功能如下所示:

jQuery 4

立即段代码很简短,可是关乎到了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实例的实际值。

style=”text-decoration: underline;”>这么些法会更新控制器上地点的$viewValue,接下来将价值传递让各一个$parser函数(包括验证器)。当值被分析,且$parser流水线中有的函数都调用完成后,值会被授予给$modelValue属性,并且传递让指令中ng-model属性提供的表明式。最后,所有手续都得后, style=”color: #333399;”>$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相反。

学了基础之知识点, 需要深切上下从定义表达的写法,已经ng1.3自此对证实指令的易用性有所提升。

 未完待续….

    
备注:我呢是刚刚开端学习,假设您欢喜本文的话,推荐共勉,谢谢!

 

相关文章

网站地图xml地图