angularcli 第五篇(输入框、表单处理)
注:涉及input表单时要在AppComponent中引入 FormsModule模块:
import{ FormsModule } from '@angular/forms'; @NgModule({ imports: [BrowserModule, FormsModule],})
目录:
1、在 Angular 表单中,通过 [(ngModel)]="username" 指令来实现数据双向绑定
2、添加简单的验证功能
3、显示表单验证失败的错误信息
4、创建表单(添加name属性)
5、获取表单提交的值
6、对表单输入内容进行分组 ngModelGroup
7、为表单的验证状态添加样式信息
8、为表单的验证状态添加样式信息
9、使用单选控件
10、使用多选控件
11、为多选控件添加必填验证
<!-- 下面的代码均是html中,同时在typescript中要定义username的初始值 -->
username = 'semlinker';
1、简单的输入框(双向绑定)
在angular表单中通过 ngModel 指令来实现双向绑定。
<!-- 1、在 Angular 表单中,通过 [(ngModel)]="username" 指令来实现数据双向绑定 --> <input type="text" name="111" [(ngModel)]="username">
{{username}} <!-- 获取输入框中输入的值 -->
2、表单验证功能
(1)目前 Angular 支持的内建 validators 如下:
required - 表单控件值是必填的
email - 表单控件值的格式是 email
minlength - 表单控件值的最小长度
maxlength - 表单控件值的最大长度
pattern - 表单控件的值需匹配 pattern 对应的模式
(2)如何判断表单控件是否通过验证?
在 Angular 中,我们可以通过 #userName="ngModel" 方式获取 ngModel 对象,然后通过 userName.valid 判断表单控件是否通过验证。
<!-- 2、添加简单的验证功能 -->
<input type="text" required [(ngModel)]="username" #userName="ngModel">{{userName.valid}}
3、显示验证失败的错误信息
在 Angular 中,可以通过 #userName="ngModel" 方式获取 ngModel 对象,然后通过该对象的 errors 属性,来获取对应验证规则 (如 required, minlength 等) 的验证状态。
<!-- 3、显示表单验证失败的错误信息 -->
<input type="text" required minlength="3" [(ngModel)]="username" #userName="ngModel"> <!-- 必填、最小长度为3 -->
<div *ngIf="userName.errors?.required">请您输入用户名</div> <!-- 输入框为空时提示“请输入用户名” -->
<div *ngIf="userName.errors?.minlength"> <!-- 长度小于最小长度时提示“用户名长度必须大于xx,当前长度xx” -->
用户名的长度必须大于 {{userName.errors?.minlength.requiredLength}},当前的长度为{{userName.errors?.minlength.actualLength}}
</div>
4、创建表单
使用<form> 标签来创建表单,一定要注意在使用 <form> 标签后,我们的 input 输入框,必须添加 name 属性。
<!-- 4、创建表单(添加name属性) -->
<form>
<input name="userName" type="text" required minlength="3"[(ngModel)]="username" #userName="ngModel">
<div *ngIf="userName.errors?.required">请您输入用户名</div>
<div *ngIf="userName.errors?.minlength">
用户名的长度必须大于 {{userName.errors?.minlength.requiredLength}},当前的长度为{{userName.errors?.minlength.actualLength}}
</div>
<button type="submit">提交</button>
</form>
5、获取表单提交的值
在 Angular 中,我们可以通过 #loginForm="ngForm" 方式获取 ngForm 对象,然后通过 loginForm.value 来获取表单的值。
<!-- 5、获取表单提交的值 -->
<form #loginForm="ngForm" (ngSubmit)="onSubmit(loginForm.value)">
<input type="text" required minlength="3" name="username" [(ngModel)]="username" #userName="ngModel">
<div *ngIf="userName.errors?.required">请您输入用户名</div>
<div *ngIf="userName.errors?.minlength">
用户名的长度必须大于 {{userName.errors?.minlength.requiredLength}},当前的长度为{{userName.errors?.minlength.actualLength}}
</div>
<button type="submit">提交</button>
{{loginForm.value | json}}
</form>
<!-- typescript的内容 -->
export class AppComponent {
username = 'semlinker'; 15 onSubmit(value) {
16 console.log(value); //打印出来是输入框的值
17 }
打印结果: 
6、对表单输入内容进行分组 ngModelGroup
ngModelGroup 指令是 Angular 表单中提供的另一特殊指令,可以对表单输入内容进行分组,方便我们在语义上区分不同性质的输入。
例如联系人的信息包括姓名及住址,现在需对姓名和住址进行精细化信息收集,姓名可精细化成姓和名字,地址可精细化成城市、区、街等。
<!-- 6、对表单输入内容进行分组 ngModelGroup -->
<form #loginForm="ngForm" (ngSubmit)="onSubmit(loginForm.value)">
<fieldset ngModelGroup="user">
<input type="text" required minlength="3" name="username" [(ngModel)]="username" #userName="ngModel">
<div *ngIf="userName.errors?.required">请您输入用户名</div>
<div *ngIf="userName.errors?.minlength">
用户名的长度必须大于 {{userName.errors?.minlength.requiredLength}},当前的长度为 {{userName.errors?.minlength.actualLength}}
</div>
<input type="password" ngModel name="password">
</fieldset>
<button type="submit">提交</button>
{{loginForm.value | json}}
</form> <!-- typescript -->
export class AppComponent {
username = 'semlinker'; onSubmit(value) {
console.dir(value);
}
}
以上代码成功运行后,{{loginForm.value | json}} 和控制台的输出结果:{ "user": { "username": "semlinker", "password": "123" } }
7、为表单的验证状态添加样式信息
在 Angular 表单中,若验证通过则会在表单控件上添加 ng-valid 类,若验证失败则会在表单控件上添加 ng-invalid 类。
<!-- 7、为表单的验证状态添加样式信息 -->
2 <!-- 在上例的基础上添加 css 代码 -->
input.ng-invalid {
border: 3px solid red;
}
input.ng-valid {
border: 3px solid green;
}
8、表单控件的状态
在 Angular 中可以通过 #userName="ngModel" 方式获取 ngModel 对象,进而获取控件的状态信息。
表单控件有以下 6 种状态:
valid - 表单控件有效
invalid - 表单控件无效
pristine - 表单控件值未改变
dirty - 表单控件值已改变
touched - 表单控件已被访问过
untouched - 表单控件未被访问过
<!-- 8、为表单的验证状态添加样式信息 -->
<input type="text" [(ngModel)]="username" #userName="ngModel"> <p>Name控件的valid状态:{{userName.valid}} - 表示控件有效</p>
<p>Name控件的invalid状态:{{userName.invalid}} - 表示控件无效</p>
<p>Name控件的pristine状态:{{userName.pristine}} - 表示控件值未改变</p>
<p>Name控件的dirty状态:{{userName.dirty}} - 表示控件值已改变</p>
<p>Name控件的touched状态:{{userName.touched}} - 表示控件已被访问过</p>
<p>Name控件的untouched状态:{{userName.untouched}} - 表示控件未被访问过</p>
9、使用单选控件
在 Angular 中,我们通过 <input name="***" type="radio"> 方式添加单选控件。
<!-- 9、使用单选控件 -->
<form #loginForm="ngForm">
<div *ngFor="let color of colors;">
<input [attr.id]="color" name="color" ngModel required [value]="color" type="radio">
<label [attr.for]="color">{{color}}</label>
</div>
{{loginForm.value | json}}
</form> <!-- typescript -->
export class AppComponent {
colors = ['红色', '黄色', '蓝色];
}
9 <p>Name控件的untouched状态:{{userName.untouched}} - 表示控件未被访问过</p>
10、使用多选控件
在 Angular 中,通过 <select name="***"> 方式添加多选控件。
<!-- 10、使用多选控件 -->
<form #loginForm="ngForm">
<select name="color" [ngModel]="colors[0]">
<option *ngFor="let color of colors;" [value]="color">
{{color}}
</option>
</select>
{{loginForm.value | json}}
</form> <!-- typescript -->
export class AppComponent {
colors = ['红色', '黄色', '蓝色];
}
11、为多选控件添加必填验证
<!-- 11、为多选控件添加必填验证 -->
<form #loginForm="ngForm">
<div>
<select name="color" [ngModel]="colors[0]" required>
<option *ngFor="let color of colors;" [value]="color">
{{color}}
</option>
</select>
<label></label>
</div>
{{loginForm.value | json}}
</form> <!-- css -->
select.ng-invalid + label:after {
content: '<-- 请做出选择!'
}
<!-- typescript -->
export class AppComponent {
colors = ['红色', '黄色', '蓝色];
}
angularcli 第五篇(输入框、表单处理)的更多相关文章
- struts2官方 中文教程 系列五:处理表单
先贴个本帖的地址,免得其它网站被爬去了struts2教程 官方系列五:处理表单 即 http://www.cnblogs.com/linghaoxinpian/p/6906298.html 下载本章 ...
- 2017.2.28 activiti实战--第七章--Spring容器集成应用实例(五)普通表单
学习资料:<Activiti实战> 第七章 Spring容器集成应用实例(五)普通表单 第六章中介绍了动态表单.外置表单.这里讲解第三种表单:普通表单. 普通表单的特点: 把表单内容写在 ...
- angularjs学习第五天笔记(第二篇:表单验证升级篇)
您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点 ...
- [AngularJS] AngularJS系列(3) 中级篇之表单验证
目录 基本验证 验证插件messages 自定义验证 基本验证 <form name="form" novalidate ng-app> <span>{{f ...
- HTML5学习笔记五:html5表单
表单是页面上非常重要的一块内容,用户可输入的大部分内容都是在表单元素中完成的,与后台的交互大多数也是通过点击表单中的按钮. 一.新增的元素和属性 1.新增属性: 1.1 form属性:页面中的任何元素 ...
- Gemini.Workflow 双子工作流入门教程五:业务表单开发
简介: Gemini.Workflow 双子工作流,是一套功能强大,使用简单的工作流,简称双子流,目前配套集成在Aries框架中. 下面介绍本篇教程:业务表单开发. 业务表单开发 业务表单的开发,和在 ...
- AngularJS(五):表单及输入验证
本文也同步发表在我的公众号“我的天空” 表单基础 表单是HTML中很重要的一个部分,基本上我们的信息录入都依靠表单,接下来我们学习如何在AngularJS中使用表单,首先看以下示例代码: <bo ...
- 第五节:表单标签的用法——value绑定和修饰符
1.表单标签的用法--value绑定和修饰符 value绑定的写法:v-bind:value 或者简写 :value 修饰符: lazy , Number , trim . 用法如: v-model ...
- Struct2(五)处理表单
简介: 1.表单的提交 表单和对应的Java模型的类 在此次的例子中,我们将会模仿一个用户提交表单的动作,具体提交表单做什么,不关心,我们需要知道 first last Name,Email addr ...
随机推荐
- k8s记录-国内下载k8s组件镜像
#!/bin/sh ### 版本信息 K8S_VERSION=v1.13.2 ETCD_VERSION=3.2.24 DASHBOARD_VERSION=v1.8.3 FLANNEL_VERSION= ...
- Elasticsearch探索之路的障碍
1. unable to install syscall filter 解决方法: 这个警告主要输因为使用的linux版本过低造成的 暂时不用理会
- EasyDSS高性能RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器软件对数据库Sqlite3和MySQL的支持说明
背景分析 EasyDSS商用流媒体服务器提供一站式的转码.点播.直播.时移回放服务,极大地简化了开发和集成的工作,并且EasyDSS支持多种特性,完全能够满足企业视频信息化建设方面的需求.其中,点播功 ...
- Docker Overview
Docker 是一个用于开发.交付和运行应用的开放平台,Docker 设计用来更快的交付你的应用程序.Docker 可以将你的应用程序和基础设施层隔离,并且还可以将你的基础设施当作程序一样进行管理.D ...
- [ARM-LInux开发]linux设备驱动makefile入门解析
以下内容仅作参考,能力有限,如有错误还请纠正.对于一个普通的linux设备驱动模块,以下是一个经典的makefile代码,使用下面这个makefile可以完成大部分驱动的编译,使用时只需要修改一下要编 ...
- .NET Core sdk和runtime区别
SDK和runtime区别 .net core Runtime[跑netcore 程序的] (CoreCLR) .net core SDK (开发工具包 [runtime(jre) + Rolysn( ...
- 第2课,python while循环的使用
引言: 上次课学习了python turtle库的基本使用,向前向后和转向.本次课需要画多个图形,简单的东西多起来就变得不简单了. 0/1是简单的,但却能组成丰富多彩的多媒体世界. 课程内容: 1. ...
- C语言开发中常见报错的解决方案
C语言开发中常见报错的解决方案 整理来源于网络,侵权请通知删除.*禁止转载 ---- fatal error C1003: error count exceeds number; stopping c ...
- SqlServer调用OPENQUERY函数远程执行增删改查
/* OPENQUERY函数,远程执行数据库增删改查 关于OPENQUERY函数第二个参数不支持拼接变量的方案 方案1:将OPENQUERY语句整个拼接为字符串,再用EXEC执行该字符串语句 方案2: ...
- vuex的Store简单使用过程
介绍 Store的代码结构一般由State.Getters.Mutation.Actions这四种组成,也可以理解Store是一个容器,Store里面的状态与单纯的全局变量是不一样的,无法直接改变st ...