构建一个ng表单
1.确保form上标签有一个name属性,像下面的例子一样。最好再加一个novalidate=”novalidate”
2.form中不能有action属性。提交交由ng-submit处理
3.每个input一定要有ng-model,最好有一个name方便引用。然后用require或者ng-minlength之类才起作用
<form name="form" novalidate="novalidate"> <label name="email">Your email</label> <input type="email" name="email" ng-model="email" placeholder="Email Address" /> </form>
ng默认提供了验证
验证是否已输入文字,只需在标签上加上required:
<input type="text" ng-model="user.name" required />
验证至少输入{number}个字符,使用指令ng-minlength=“{number}”:
<input type="text" ng-model="user.name" ng-minlength="5" />
验证至多输入{number}个字符,使用指令ng-maxlength=“{number}”:
<input type="text" ng-model="user.name" ng-maxlength="20" />
确保输入匹配一个正则表达式,使用指令ng-pattern="/PATTERN/":
<input type="text" ng-model="user.name" ng-pattern="/a-zA-Z/" />
验证输入是一个Email,设置input的type属性为email:
<input type="email" name="email" ng-model="user.email" />
验证输入是一个数字,设置input的type属性为number:
<input type="number" name="number" ng-model="user.age" />
验证输入是一个URL,设置input的type属性为url
<input type="url" name="homepage" ng-model="user.weburl" />
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="https://cdn.static.runoob.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>
结果为:
验证实例
用户名:
邮箱:
邮箱是必须的。
解析
AngularJS ng-model 指令用于绑定输入元素到模型中。
模型对象有两个属性: user 和 email。
我们使用了 ng-show指令, color:red 在邮件是 $dirty 或 $invalid 才显示。
$dirty 表单有填写记录
$valid 字段内容合法的
$invalid 字段内容是非法的
$pristine 表单没有填写记录
相关推荐
4. **表单处理和验证**:AngularJS提供了内置的表单验证机制,可以实时检查用户输入,并在视图中显示验证状态。 5. **服务**:AngularJS的服务是可重用的代码块,如$http服务用于发起HTTP请求,$rootScope服务是...
在本文中,我们将深入探讨如何使用Angular.js框架创建一个功能丰富的日期选择器。...无论是在表单中收集日期信息,还是在应用程序的其他部分展示日期,基于Angular.js的日期选择器都是一个实用的解决方案。
9. **表单处理**:AngularJS提供了内置的表单验证和模型绑定,如`ng-model`用于绑定输入字段,`ng-valid`、`ng-invalid`用于状态检查。1.6.9版本进一步优化了表单处理的性能和用户体验。 10. **动画**:AngularJS的...
在上面的示例代码中,我们使用了 Angular.js 的表单验证功能,来验证用户输入的注册信息。例如,我们可以使用 `ng-required` 指令来设置输入框内必需填写内容,使用 `ng-pattern` 指令来设置正则验证规则。 总结 ...
8. **表单和验证**:Angular提供了内置的表单处理和验证机制,使得客户端验证变得更加简单。 9. **过滤器**:过滤器用于格式化或转换数据,例如日期格式化、货币转换或数组排序。 10. **测试**:Angular支持单元...
8. **表单处理**:AngularJS提供了表单验证和数据绑定,使得表单的处理变得更加直观和便捷。 9. **单元测试和端到端测试**:AngularJS支持 Karma 和 Jasmine 进行单元测试,Protractor 用于端到端测试,确保应用的...
1. 表单验证:AngularJS内置的表单验证机制可以实时反馈用户输入的有效性,提升用户体验。 2. 数据绑定:通过双向数据绑定,可以轻松实现表格、下拉框等组件的数据展示和编辑。 3. RESTful API通信:利用$http服务与...
4. **表单处理**:Angular.js提供了内置的表单验证机制,通过ng-model、ng-required等指令实现。 5. **测试**:支持单元测试和端到端测试,如 Karma 和 Protractor 工具。 五、迁移与升级 虽然Angular.js 1.8.0...
7. **表单和验证(Forms and Validation)**:Angular.js 1.4.0提供了强大的表单处理和验证功能,可以轻松实现客户端验证,提升用户体验。 8. **动画(Animations)**:AngularJS 1.4.0引入了更完善的动画API,使得...
这个压缩包“angular-angular.js-v1.4.5-15-gc71d414.zip”包含了AngularJS 1.4.5版本的源代码,这是一个重要的中间版本,具有显著的改进和修复。 1. 版本号解析: - "v1.4.5" 表示这是AngularJS 1.x系列中的第1....
7. 表单处理:AngularJS提供了内置的表单和字段验证机制,如ngModel、ngSubmit、ngRequired等,能够方便地实现客户端验证,提升用户体验。 8. 过滤器(Filters):过滤器用于格式化和转换数据,例如日期格式化、...
6. 表单处理:Angular.js提供了内置的表单验证和模型驱动的表单,简化了表单的创建和管理。 7. 服务:Angular.js的服务是一种可注入的实体,用于封装应用中的业务逻辑或数据访问,如$http服务用于发送HTTP请求,$...
6. 表单验证:Angular.js提供了内置的表单验证机制,可以用来确保用户输入正确。本例中,使用了confirm弹窗来询问用户是否真的想要删除商品,这可以视为一种简单的验证。 7. 计算总价格:通过遍历商品数组,并累加...
8. **表单处理(Form Handling)**:Angular.js提供了强大的表单处理能力,包括验证和模型绑定。在银行应用中,表单可能用于输入转账金额和接收方账号,Angular.js会自动处理这些输入。 9. **测试**:Angular.js...
下面我将详细解释Angular2.js实现表单验证的知识点。 首先,我们需要了解Angular表单的两种类型:模板驱动表单和响应式表单。模板驱动表单是较为简单的一种形式,适用于简单的表单需求。响应式表单提供了更细粒度的...
7. **表单验证**:Angular.js 提供了内置的表单验证机制,允许在客户端对用户输入进行实时验证。通过`ng-model`和`ng-required`等属性,可以轻松实现表单验证。 8. **路由**:AngularJS 使用`ngRoute`或`ui-router`...
此外,还会涉及数据绑定、服务注入、路由、表单验证等Angular核心概念,以及如何利用Angular CLI工具进行开发和测试。通过实际项目案例,读者可以深入理解Angular 8与Material Design的集成,并提升开发效率和应用...
Angular.js是一个非常流行的JavaScript框架,主要用于开发动态的单页面应用程序。在Angular.js中,ng-app和ng-model是两个非常核心的指令(directives),它们分别用于启动Angular.js应用和数据绑定。 首先,让我们...
模板驱动表单使用ngModel指令,而响应式表单基于FormControl对象,提供更高级别的控制和验证。 6. **模块化**:Angular 4引入了NgModule,它是Angular应用的构造块。每个模块可以包含组件、指令、管道和服务,使得...
表单和表单验证** Angular.js提供了一套完整的表单处理机制,包括表单的脏值检查、表单状态管理以及客户端验证。通过 ngModel 指令,我们可以轻松地将表单控件与模型绑定,并利用内置的验证规则进行实时验证。 综...