AngularJS 输入验证详解及实例代码


Posted in Javascript onJuly 28, 2016

AngularJS 输入验证

AngularJS 表单和控件可以验证输入的数据。

输入验证

在前面的几个章节中,你已经学到关于 AngularJS 表单和控件的知识。

AngularJS 表单和控件可以提供验证功能,并对用户输入的非法数据进行警告。

注意: 客户端的验证不能确保用户输入数据的安全,所以服务端的数据验证也是必须的。

应用代码

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<h2>验证实例</h2>

<form ng-app="myApp" ng-controller="validateCtrl" 
name="myForm" novalidate>

<p>用户名:<br>
<input type="text" name="user" ng-model="user" required>
<span style="color:red" ng-show="myForm.user.$dirty && myForm.user.$invalid">
<span ng-show="myForm.user.$error.required">用户名是必须的。</span>
</span>
</p>

<p>邮箱:<br>
<input type="email" name="email" ng-model="email" required>
<span style="color:red" ng-show="myForm.email.$dirty && myForm.email.$invalid">
<span ng-show="myForm.email.$error.required">邮箱是必须的。</span>
<span ng-show="myForm.email.$error.email">非法的邮箱地址。</span>
</span>
</p>

<p>
<input type="submit"
ng-disabled="myForm.user.$dirty && myForm.user.$invalid || 
myForm.email.$dirty && myForm.email.$invalid">
</p>

</form>

<script>
var app = angular.module('myApp', []);
app.controller('validateCtrl', function($scope) {
 $scope.user = 'John Doe';
 $scope.email = 'john.doe@gmail.com';
});
</script>

</body>
</html>

运行结果:

 验证实例

用户名:

邮箱:

注意: HTML 表单属性 novalidate 用于禁用浏览器默认的验证。

实例解析

AngularJS ng-model 指令用于绑定输入元素到模型中。

模型对象有两个属性: user email

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

 

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

 以上就是对AngularJS 输入验证的资料整理,后续继续补充,希望能帮助学习的同学。

Javascript 相关文章推荐
一个关于javascript匿名函数的问题分析
Mar 30 Javascript
javascript常用对话框小集
Sep 13 Javascript
jquery判断小数点两位和自动删除小数两位后的数字
Mar 19 Javascript
AngularJS基础 ng-keyup 指令简单示例
Aug 02 Javascript
需要牢记的JavaScript基础知识
Sep 25 Javascript
easyui-combobox 实现简单的自动补全功能示例
Nov 08 Javascript
js事件源window.event.srcElement兼容性写法(详解)
Nov 25 Javascript
拖动时防止选中
Feb 03 Javascript
详解如何使用webpack+es6开发angular1.x
Aug 16 Javascript
jQuery实现checkbox的简单操作
Nov 18 jQuery
vue项目中使用Svg的方法
Oct 24 Javascript
详解ES6系列之私有变量的实现
Nov 21 Javascript
jquery实用技巧之输入框提示语句
Jul 28 #Javascript
jQuery stop()用法实例详解
Jul 28 #Javascript
AngularJS中的表单简单入门
Jul 28 #Javascript
jQuery插件Validation快速完成表单验证的方式
Jul 28 #Javascript
浅谈JS正则表达式的RegExp对象和括号的使用
Jul 28 #Javascript
AngularJS 模块详解及简单实例
Jul 28 #Javascript
jQuery制作网页版选项卡
Jul 28 #Javascript
You might like
php自动注册登录验证机制实现代码
2011/12/20 PHP
php缩小png图片不损失透明色的解决方法
2013/12/25 PHP
Linux下PHP加速器APC的安装与配置笔记
2014/10/24 PHP
PHP简单生成缩略图相册的方法
2015/07/29 PHP
使用ThinkPHP的自动完成实现无限级分类实例详解
2016/09/02 PHP
thinkphp多表查询两表有重复相同字段的完美解决方法
2016/09/22 PHP
php发送http请求的常用方法分析
2016/11/08 PHP
thinkphp3.2实现跨控制器调用其他模块的方法
2017/03/14 PHP
PHP类的自动加载机制实现方法分析
2019/01/10 PHP
javascript调试说明
2010/06/07 Javascript
Javascript面向对象设计一 工厂模式
2011/12/20 Javascript
分析Node.js connect ECONNREFUSED错误
2013/04/09 Javascript
用innerhtml提高页面打开速度的方法
2013/08/02 Javascript
JS复制内容到剪切板的实例代码(兼容IE与火狐)
2013/11/19 Javascript
nodejs教程之入门
2014/11/21 NodeJs
jQuery中复合属性选择器用法实例
2014/12/31 Javascript
分享两个手机访问pc网站自动跳转手机端网站代码
2020/12/24 Javascript
瀑布流的实现方式(原生js+jquery+css3)
2020/06/28 Javascript
对Angular.js Controller如何进行单元测试
2016/10/25 Javascript
nodejs aes 加解密实例
2018/10/10 NodeJs
基于iview的router常用控制方式
2019/05/30 Javascript
js实现菜单跳转效果
2020/12/11 Javascript
Flask框架实现的前端RSA加密与后端Python解密功能详解
2019/08/13 Python
django创建简单的页面响应实例教程
2019/09/06 Python
详解Python的爬虫框架 Scrapy
2020/08/03 Python
巴西网上药店:Drogaria Araujo
2021/01/06 全球购物
JSF界面控制层技术
2013/06/17 面试题
个人简历自我鉴定
2013/10/11 职场文书
求职信的要素有哪些呢
2013/12/26 职场文书
临床护士自荐信
2014/01/31 职场文书
《阳光》教学反思
2014/02/23 职场文书
《秋姑娘的信》教学反思
2014/02/28 职场文书
有创意的广告词
2014/03/18 职场文书
党员民主生活会整改措施
2014/09/26 职场文书
用电申请报告范文
2015/05/18 职场文书
Python采集壁纸并实现炫轮播
2022/04/30 Python