• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >AngularJS > AngularJs表单验证实例详解

AngularJs表单验证实例详解

作者:Halower 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含AngularJs表单验证实例详解等相关知识,Halower 希望在学习及工作中可以帮助到您

常用的表单验证指令

1. 必填项验证

某个表单输入是否已填写,只要在输入字段元素上添加HTML5标记required即可:

2. 最小长度

验证表单输入的文本长度是否大于某个最小值,在输入字段上使用指令ng-minleng= "{number}":

3. 最大长度

验证表单输入的文本长度是否小于或等于某个最大值,在输入字段上使用指令ng-maxlength="{number}":

4. 模式匹配

使用ng-pattern="/PATTERN/"来确保输入能够匹配指定的正则表达式:

5. 电子邮件

验证输入内容是否是电子邮件,只要像下面这样将input的类型设置为email即可:

6. 数字

验证输入内容是否是数字,将input的类型设置为number:

7. URL

验证输入内容是否是URL,将input的类型设置为 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>
</div>

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

似乎并没有发生什么问题,但是如果我们将其移植到一个队HTML5验证不怎么好的浏览器再来测试一下【本例IE9】,问题来了,某些字段完全没得验证

其实,上面的例子,我们利用了HTML5的验证与ng自有的验证进行了结合,不支持HTML5验证,但ng自由验证运行良好。解决方案很简单,可以使用模式匹配的方式解决这几种情况,也可以自定义验证指令来复写或者重定义验证规则。

屏蔽浏览器对表单的默认验证行为

在表单元素上添加novalidate标记即可,问题是我们怎么知道我们的表单有哪些字段是有效的,那些事非法或者无效的?ng对此也提供了非常棒的解决方案,表单的属性可以在其所属的$scope对象中访问到,而我们又可以访问$scope对象,因此JavaScript可以间接地访问DOM中的表单属性。借助这些属性,我们可以对表单做出实时响应。

可以使用formName.inputFieldName.property的格式访问这些属性。

未修改过的表单

布尔值属性,表示用户是否修改了表单。如果为ture,表示没有修改过;false表示修改过:

布尔型属性,当且仅当用户实际已经修改的表单。不管表单是否通过验证:

您可能想查找下面的文章:

相关文章

  • 2017-05-30基于AngularJS实现页面滚动到底自动加载数据的功能
  • 2017-05-30使用AngularJS对路由进行安全性处理的方法
  • 2017-05-30AngularJS基础 ng-show 指令简单示例
  • 2017-05-30使用AngularJS创建自定义的过滤器的方法
  • 2017-05-30详解Angular 4.x NgIf 的用法
  • 2017-05-30AngularJS整合Springmvc、Spring、Mybatis搭建开发环境
  • 2017-05-30AngularJS表单编辑提交功能实例
  • 2017-05-30AngularJS入门教程(零):引导程序
  • 2017-05-30AngularJS路由实现页面跳转实例
  • 2017-05-30Angular设置title信息解决SEO方面存在问题

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • angularjs 源码解析之scope
    • 走进AngularJs之过滤器(filter)详解
    • 通过AngularJS实现图片上传及缩略图展示示例
    • AngularJS 与百度地图的结合实例
    • AngularJS 实现弹性盒子布局的方法
    • AngularJs根据访问的页面动态加载Controller的解决方案
    • 仿Angular Bootstrap TimePicker创建分钟数-秒数的输入控件
    • 浅谈angular2的http请求返回结果的subcribe注意事项
    • AngularJS教程 ng-style 指令简单示例
    • angularjs客户端实现压缩图片文件并上传实例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有