使用AngularJS对表单提交内容进行验证的操作方法
AngularJS是一款优秀的前端JS框架,已经被用于Google的多款产品当中。它有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等……使用它可以大大减少书写代码的工作量,但和Jquery不同,使用AngularJS有一定的难度,因此今天我将介绍以下怎样使用AngularJS来对表单的提交内容进行验证。
AngularJS对表单中常用的验证操作
$dirty 表单有填写记录
$valid 字段内容合法的
$invalid 字段内容是非法的
$pristine 表单没有填写记录
$error 表单验证不通过的错误信息
1.相关插件的导入:AngularJS和Jquery一样,是一种由程序员用js编写好然后封装起来的js插件,因此在使用之前要用以下代码来导入它。
<script src="libs/angular.js"></script>
注:该js插件最好放在body之后,自己写的js代码则放在AngularJS之后防止产生错误。
2.在导入完AngularJS插件之后,我们首先要在body中创建一个form表单,用于接下来的操作,然后在表单上或者body上加上ng-app=""属性来确定AngularJS的作用域,一般
推荐加在body上。
<body ng-app="app" ng-controller="ctrl"></body>
注:ng-controller="ctrl"用于设置控制器。
3.给form表单和input的name属性命名,给form及input设置name后会将form表单信息默认绑定到$scope作用域中,故可以使用formName.inputName.$验证操作 得到验证结果。
<form class="form-horizontal" name="myForm" novalidate> <input type="text" name="name" > <input type="email" name="mail"> <input type="password" name="pwd" > </form>
novalidata用于禁止h5自带的表单验证,防止多余影响。
例如:
myForm.text.$dirty="true";表单被填写过 myForm.text.$invalid"true";表单输入不合法 myForm.text.$error.required="true";表单必填但未填。
4.给input加上对应的验证:
<input type="text" name="name" ng-minlength="4" ng-maxlength="10" required ng-class="{erro:myForm.name.$invalid&&myForm.name.$dirty}"/> <input type="email" name="mail" required /> <input type="password" name="pwd" ng-model="user.pwd" pattern="^\w{6,18}$"/>
注:
以上代码对text设置了最小长度4,最大长度10,必填的验证信息,
对email则使用了email自带验证,增加了必填要求,
对password则是设置了正则验证要求是6到18位的字母数字下划线。
5.给提交按钮加上ng-disabled="myForm.$dirty&&myForm.$invalid
"属性在表单输入不合法时将按钮禁用来阻止表单内容提交。
注:myForm.$dirty&&myForm.$invalid表示在表单有输入的情况下输入错误。
以上步骤完成之后表单的验证就完成了,也可以加上span的ng-show="myForm.name.$invalid&&myForm.name.$dirty
"属性来设置在不同错误时出现不同的提示信息,这样,一个可以验证是否提交的表单就完成了。
以上所述是小编给大家介绍的使用AngularJS对表单提交内容进行验证的操作方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
相关文章
详解Angularjs在控制器(controller.js)中使用过滤器($filter)格式化日期/时间实例
本篇文章主要介绍了详解Angularjs在控制器(controller.js)中使用过滤器($filter)格式化日期/时间实例 ,有需要的小伙伴可以参考下。2017-02-02Angularjs编写KindEditor,UEidtor,jQuery指令
使用过 AngularJS 的朋友应该最感兴趣的是它的指令。现今市场上的前端框架也只有AngularJS 拥有自定义指令的功能,并且AngularJS 是目前唯一提供Web应用可复用能力的框架。2015-01-01AngularJS学习笔记之基本指令(init、repeat)
AngularJS 指令是扩展的 HTML 属性,带有前缀 ng-。ng-app 指令初始化一个 AngularJS 应用程序。ng-init 指令初始化应用程序数据。ng-model 指令把应用程序数据绑定到 HTML 元素。2015-06-06angular2 ng2 @input和@output理解及示例
本篇文章主要介绍了angular2 ng2 @input和@output理解及示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-10-10AngularJS 与Bootstrap实现表格分页实例代码
这篇文章主要介绍了AngularJS 与Bootstrap实现表格分页的相关资料,并附实例代码和实现效果图,需要的朋友可以参考下2016-10-10
最新评论