对于Angular2.0 的Form表单中的隐藏和验证,个人觉得还是挺有意思的。
1.通过ngModel 跟踪修改状态与验证。
在表单中使用 ngModel 可以获得更多的控制权,包括一些常用的验证。
ngModel 不仅仅可以跟踪状态(表单中各个控件的状态)还可以用特定的Angular CSS 类来更新控件,以表达当前的状态
(如显示和隐藏)
ng-touched:控件已被访问过的css 类; ng-untouched 为没有被访问过的CSS 类
ng-dirty :控件值已经发生变化,ng-pristine 没有
ng-valid 控件值有效;ng-invalid 无效
如下,我们可以通过这种方式对class name 进行监控
先设置css
.ng-valid[required], .ng-valid.required { border-left: 5px solid #42A948; /* green */ } .ng-invalid:not(form) { border-left: 5px solid #a94442; /* red */ }
然后通过param.className监控
<input type="text" class="form-control" id="name" required [(ngModel)]="model.name" name="name" #param > <br> current class name :{{param.className}}
2.显示和隐藏验证提示信息
<label for="name">Name</label> <input type="text" class="form-control" id="name" required [(ngModel)]="model.name" name="name" #name="ngModel" > <div [hidden]="name.valid || name.pristine" class="alert alert-danger"> Name is required </div>
需要注意的是,我们在input 标签中添加了个#name 变量。然后将ngModel 赋值给这个参数。
后年的name.valid 和 name.pristine 中的name 是这个参数变量 name
为什么是 “ngModel”? 指令的 exportAs 属性告诉 Angular 如何链接模板引用变量到指令。 这里把name
设置为ngModel
是因为ngModel
指令的exportAs
属性设置成了 “ngModel“
3.ngSubmit 和ngForm
ngForm 是Angular 自己创建的指令,并附加到form 标签上。
他是为了给form 元素扩充额外的特性。 它持有通过ngModel
指令和name
属性为各个元素创建的那些控件,并且监视它们的属性变化,包括有效性。
它还有自己的valid
属性,只有当其中所有控件都有效时,它才有效。
<div [hidden]="submitted"> <h1>Form</h1> <form (ngSubmit)="onSubmit()" #heroForm="ngForm"> <div class="form-group"> <label for="name">Name</label> <input type="text" class="form-control" id="name" required name ="name" [(ngModel)]="model.name" #name="ngModel"> <div [hidden]="name.valid || name.pristine" class="alert alert-danger">Name is required</div> </div> <div class="form-group"> <label for="alterEgo">Alter Ego</label> <input type="text" class="form-control" id="alterEgo" [(ngModel)]="model.alterEgo" name ="alterEgo"> </div> <div class="form-group"> <label for="power">Hero Power</label> <select id="power" class="form-control" required [(ngModel)]="model.power" name ="power"> <option *ngFor ="let pow of powers" [value]="pow">{{pow}}</option> </select> </div> <button class="btn btn-default" [disabled] ="!heroForm.form.valid" >Submit</button> </form> </div>
如上code 将ngForm 赋值给一个变量,这样这个变量就代表了这个form的整体,并且可以通过这个变量来获取form 的属性。