表单验证<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=""
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=""
ng-maxlength=""
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">.必填项</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">.最小长度=</label>
</div>
<div class="col-md-8">
<input type="text" id="minlength" name="minlength" ng-minlength="" 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">.最大长度=</label>
</div>
<div class="col-md-8">
<input type="text" id="maxlength" name="maxlength" ng-model="user.maxlength" ng-maxlength="" 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">. 模式匹配</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">. 电子邮件</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">. 数字</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"> . 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">
.必填项:{{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>
.最小长度=:{{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>
.最大长度=:{{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>
.模式匹配:{{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>
.电子邮件:{{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>
.数字:{{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>
.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>

angular.js表单验证的更多相关文章

  1. angular js 表单验证

    <!doctype html> <html ng-app="myapp"> <head> <meta charset="UTF- ...

  2. angular编写表单验证

    angular编写表单验证 一.整体概述 表单内容如下图,包括常用的用户名.密码.确认密码.手机.邮箱等 整体js代码很少,就一个指令用于写确认密码和密码是否相等.其他 验证都是使用angular自带 ...

  3. JS表单验证-12个常用的JS表单验证

    JS表单验证-12个常用的JS表单验证 最近有个项目用到了表单验证,小编在项目完结后的这段时间把常用的JS表单验证demo整理了一下,和大家一起分享~~~ 1. 长度限制 <p>1. 长度 ...

  4. js 表单验证控制代码大全

    js表单验证控制代码大全 关键字:js验证表单大全,用JS控制表单提交 ,javascript提交表单:目录:1:js 字符串长度限制.判断字符长度 .js限制输入.限制不能输入.textarea 长 ...

  5. jquery.validation.js 表单验证

    jquery.validation.js 表单验证   官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuer ...

  6. Jquery.validate.js表单验证插件的使用

    作为一个网站web开发人员,以前居然不知道还有表单验证这样好呀的插件,还在一行行写表单验证,真是后悔没能早点知道他们的存在. 最近公司不忙,自己学习一些东西的时候,发现了validation的一个实例 ...

  7. JS表单验证类HTML代码实例

    以前用的比较多的一个JS表单验证类,对于个人来说已经够用了,有兴趣的可以在此基础上扩展成ajax版本.本表单验证类囊括了密码验证.英文4~10个 字符验证. 中文非空验证.大于10小于100的数字.浮 ...

  8. Js表单验证控件-02 Ajax验证

    在<Js表单验证控件(使用方便,无需编码)-01使用说明>中,写了Verify.js验证控件的基本用法,基本可以满足大多数验证需求,如果涉及服务端的验证,则可以通过Ajax. Ajax验证 ...

  9. jQuery.validate.js表单验证插件

    jQuery.validate.js表单验证插件的使用 效果: 代码: <!DOCTYPE html> <html lang="en"> <head& ...

随机推荐

  1. [Ynoi2015]此时此刻的光辉

    题目大意: 给定一个序列,每次询问一段区间的数的乘积的约数个数. 解题思路: 在太阳西斜的这个世界里,置身天上之森.等这场战争结束之后,不归之人与望眼欲穿的众人, 人人本着正义之名,长存不灭的过去.逐 ...

  2. BZOJ 3514 GERALD07加强版 (LCT+主席树)

    题目大意:给定n个点m条边无向图,每次询问求当图中有编号为[L,R]的边时,整个图的联通块个数,强制在线 神题!(发现好久以前的题解没有写完诶) 我们要求图中联通块的个数,似乎不可搞啊. 联通块个数= ...

  3. Solr学习记录:Getting started

    目录 Solr学习记录:Getting started 1.Solr Tutorial 2. A Quick Overview Solr学习记录:Getting started 本教程使用环境:jav ...

  4. Linux基础知识和命令

    1,用户登录:    root(管理员),权限最大.安全生产必要时再使用.    普通用户:权限有限.2,    终端终端设备终端:输入和输出设备,如:键盘鼠标显示器;     图形终端:虚拟机进入窗 ...

  5. Docker学习总结(16)——当当网Docker应用实践

    随着Docker成为当下热门的容器技术,各大公司以及中小团队都开始选择Docker来进行应用部署,从原有部署方式迁移到Docker方式过程中难免会遇到各种问题,本次分享主要介绍当当网个性化推荐组应用D ...

  6. 百度之星2014资格赛 1003 - Xor Sum

    先上代码: Xor Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 132768/132768 K (Java/Others)T ...

  7. faster-rcnn代码阅读1

    毫无疑问,faster-rcnn是目标检测领域的一个里程碑式的算法.本文主要是本人阅读python版本的faster-rcnn代码的一个记录,算法的具体原理本文也会有介绍,但是为了对该算法有一个整体性 ...

  8. 【FastDev4Android框架开发】打造QQ6.X最新版本号側滑界面效果(三十八)

    转载请标明出处: http://blog.csdn.net/developer_jiangqq/article/details/50253925 本文出自:[江清清的博客] (一).前言: [好消息] ...

  9. python清除数据库错误日志

    # coding=gbk from encodings import gbk  import re   import sys import  os import  pyodbc import trac ...

  10. 【cl】解决Fail to create the java Virtual Machine

    eclipse打开,提示Fail to create the java Virtual Machine 解决方法: 1.到eclipse安装目录下,找到eclipse.ini 2.按键盘ctrl+F, ...