angular.js表单验证
表单验证<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" />
实际的例子:
<form class="form-horizontal" novalidate="novalidate" name="reginForm"> <!-- form必须有一个name -->
novalidate="novalidate" 去除 h5自带的验证
<div class="panel panel-default"> <div class="panel-body"> <h3 style="text-align: center;padding: 15px 0 25px;width: 80%;">注册/登录表单</h3> <form class="form-horizontal" name="reginForm"> <!-- form必须有一个name --> <div class="form-group"> <label for="inputEmail3" class="col-sm-2 control-label">部门</label> <div class="col-sm-6"> <input type="password" name="" disabled="disabled" class="form-control" id="" placeholder="系统管理"> </div> </div> <div class="form-group" ng-class="{'has-error' : reginForm.name.$invalid && reginForm.name.$dirty}"> <!-- reginForm.name.$invalid reginForm: form 表单的name name: 需要验证的输入框的 name $invalid: 相应的输入框的验证条件 $dirty:聚焦、失焦的时候验证 --> <label for="inputEmail3" class="col-sm-2 control-label">用户名</label> <div class="col-sm-6"> <input type="text" name="name" class="form-control" id="" required="required" ng-minlength="6" ng-model="userNews.name" value="{{userNews.name}}" placeholder="请输入用户名"> <!-- userNews.name userNews 就是用户数据 name 就是 name="name" 必须有这个,有了这个才是双向绑定--> </div> </div> <div class="form-group" ng-class="{'has-error' : reginForm.password.$invalid && reginForm.password.$dirty}"> <label for="inputEmail3" class="col-sm-2 control-label">密码</label> <div class="col-sm-6"> <input type="text" name="password" class="form-control" ng-model="userNews.password" value="{{userNews.password}}" required="required" ng-minlength="6" ng-maxlength="20" ng-pattern="/[a-zA-Z]/" id="" placeholder="请输入密码"> </div> <!--<label class="col-sm-2 control-label" style="text-align: left;font-size: 12px;">密码</label>--> </div> <div class="form-group"> <label for="inputEmail3" class="col-sm-2 control-label">重复密码</label> <div class="col-sm-6"> <input type="text" name="repeatPassword" class="form-control" value="{{list.getAddress}}" id="" placeholder="请重复密码"> </div> </div> <div class="form-group" ng-class="{'has-error' : reginForm.email.$invalid && reginForm.email.$dirty}"> <label for="inputEmail3" class="col-sm-2 control-label">邮箱</label> <div class="col-sm-6"> <input type="email" class="form-control" name="email" required="required" ng-model="userNews.email" value="{{userNews.email}}" id="" placeholder="请输入邮箱"> </div> </div> <div class="form-group" ng-class="{'has-error' : reginForm.phone.$invalid && reginForm.phone.$dirty}"> <label for="inputEmail3" class="col-sm-2 control-label">手机号码</label> <div class="col-sm-6"> <input type="number" class="form-control" name="phone" required="required" ng-model="userNews.phone" ng-pattern="/^1\d{10}$/" value="{{userNews.phone}}" id="" placeholder="请输入手机号码"> </div> </div> <div class="form-group"> <label for="inputEmail3" class="col-sm-2 control-label">性别</label> <div class="col-sm-8"> <label class="radio-inline"> <input type="radio" name="inlineRadioOptions" ng-checked="chooseLine" id="inlineRadio1" value="option1"> 男 </label> <label class="radio-inline"> <input type="radio" name="inlineRadioOptions" ng-checked="chooseLineOut" id="inlineRadio2" value="option2"> 女 </label> </div> </div> <div class="form-group form-inline"> <label for="inputEmail3" class="col-sm-2 control-label">兴趣爱好</label> <div class="col-sm-8"> <div class="checkbox" style="margin-right: 10px;"> <label> <input type="checkbox" ng-model="chooseKill"> 篮球 </label> </div> <div class="checkbox" style="margin-right: 10px;"> <label> <input type="checkbox" ng-model="chooseRecommended"> 足球 </label> </div> <div class="checkbox" style="margin-right: 10px;"> <label> <input type="checkbox" ng-model="chooseSpecial"> 撩妹 </label> </div> <div class="checkbox" style="margin-right: 10px;"> <label> <input type="checkbox" ng-model="chooseNew"> 吉他 </label> </div> <div class="checkbox" style="margin-right: 10px;"> <label> <input type="checkbox" ng-model="chooseNew"> 其他 </label> </div> </div> </div> <div class="form-group"> <div class="col-sm-offset-2 col-sm-8"> <button id="submit" type="button" ng-click="submit()" ng-disabled="reginForm.$invalid" class="btn btn-primary">确定</button> <!-- ng-disabled="reginForm.$invalid" 表单在满足所有的验证信息后会将 不可 点击的效果去掉 --> </div> </div> </form> </div> </div>
中间的说明解释都在文章中有解释。
1表单 input属性 name 名字 ng-model 绑定的数据 ng-required 是否必填 ng-minlength ng-maxlength 最小、最大长度 ng-pattern 匹配模式 ng-change 值变化的回调
如果屏蔽了 h5 自带的验证:
问题是我们怎么知道我们的表单有哪些字段是有效的,那些事非法或者无效的?ng对此也提供了非常棒的解决方案,表单的属性可以在其所属的$scope对象中访问到,而我们又可以访问$scope对象,因此JavaScript可以间接地访问DOM中的表单属性。借助这些属性,我们可以对表单做出实时响应。
可以使用formName.inputFieldName.property的格式访问这些属性。
未修改过的表单
布尔值属性,表示用户是否修改了表单。如果为ture,表示没有修改过;false表示修改过:
formName.inputFieldName.$pristine;
修改的表单
布尔型属性,当且仅当用户实际已经修改的表单。不管表单是否通过验证:
formName.inputFieldName.$dirty
经过验证的表单
布尔型属性,它指示表单是否通过验证。如果表单当前通过验证,他将为true:
formName.inputFieldName.$valid
未通过验证的表单
formName.inputFieldName.$invalid
错误
这是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>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步