最近在使用ng2做前端。發現表單驗證這塊除了官網上給的示例,驗證required。其他的都要自己寫邏輯來實現。開發起來不是很方便。所以在網上找了下ng2表單驗證的資源,覺得ng2-validation不錯。所以做的例子。以便以後使用,也怕時間久了忘腦後去。 示例代碼鏈接 首先從npm包管理伺服器上下 ...
最近在使用ng2做前端。發現表單驗證這塊除了官網上給的示例,驗證required。其他的都要自己寫邏輯來實現。開發起來不是很方便。所以在網上找了下ng2表單驗證的資源,覺得ng2-validation不錯。所以做的例子。以便以後使用,也怕時間久了忘腦後去。
- 首先從npm包管理伺服器上下載安裝。
npm install ng2-validation --save
命令參數--save:使npm包信息保存在package.json文件的dependencies配置集合內。該集合是ng2正式運行的依賴集合。
- 使用方法
在模塊文件內添加引用,一般為AppModule。
app.module.ts文件
import { NgModule } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; import { FormsModule,ReactiveFormsModule } from '@angular/forms'; import { CustomFormsModule } from 'ng2-validation'; import { AppComponent } from './app.component'; import { AppTtemplateDrivenComponent } from './app-ttemplate-driven/app-ttemplate-driven.component'; import { AppModelDrivenComponent } from './app-model-driven/app-model-driven.component'; import { AppRoutingModule } from "app/app-routes.module"; import { ValidationConfigModel } from "app/Models/validation"; @NgModule({ declarations: [ AppComponent, AppTtemplateDrivenComponent, AppModelDrivenComponent ], imports: [ BrowserModule, FormsModule, AppRoutingModule, CustomFormsModule, ReactiveFormsModule ], providers: [ValidationConfigModel], bootstrap: [AppComponent] }) export class AppModule { }View Code
表單驗證的使用方式有兩種。可以靈活選擇。兩者混合使用我沒研究。其實使用一種就足夠了。
模板驅動(template driven)
GitHub上例子
<input type="text" [(ngModel)]="model.field" name="field" #field="ngModel" [rangeLength]="[5, 9]"/>
<p *ngIf="field.errors?.rangeLength">error message</p>
模型驅動(model driven)
GitHub上例子
export class AppComponent { form: FormGroup; constructor() { this.form = new FormGroup({ field: new FormControl('', CustomValidators.range([5, 9])) }); } }
<input type="text" formControlName="field"/>
<p *ngIf="demoForm.from.controls.field.errors?.rangeLength">error message</p><form [formGroup]="formGroup" (ngSubmit)="onSubmit()" #validationForm2="ngForm" >
FormGroup需要在from的dom上添加formGroup驅動,否則驗證不生效。
下麵是我的demo代碼片段:
模板驅動app-ttemplate-driven.component.html
<div class="container"> <form (ngSubmit)="onSubmit()" #validationForm="ngForm"> <div class="form-group"> <label for="appField">長度要求</label> <input type="text" required class="form-control" name="appField" [(ngModel)]="model.appField" #rangeLength="ngModel" [rangeLength]="[5, 9]"> <p [hidden]="rangeLength.valid||rangeLength.pristine">長度在5到9之間</p> </div> <div class="form-group"> <label for="appField2">長度要求2</label> <input type="text" class="form-control" name="appField2" [(ngModel)]="model.appField2" #rangeLength2="ngModel" [rangeLength]="[0,5]"> <p [hidden]="rangeLength2.valid||rangeLength2.pristine">長度要求</p> </div> <div class="form-group"> <label for="appMin">最小值</label> <input type="number" class="form-control" name="appMin" [(ngModel)]="model.appMin" #appMin="ngModel" [min]="10" /> <p [hidden]="appMin.valid||appMin.pristine">取值大於等於10</p> </div> <div class="form-group"> <label for="appGt">大於</label> <input type="number" class="form-control" name="appGt" [(ngModel)]="model.appGt" #appGt="ngModel" [gt]="10" /> <p [hidden]="appGt.valid||appGt.pristine">取值大於10</p> </div> <div class="form-group"> <label for="appGte">大於等於</label> <input type="number" class="form-control" name="appGte" [(ngModel)]="model.appGte" #appGte="ngModel" [gte]="10" /> <p [hidden]="appGte.valid||appGte.pristine">取值大於等於10</p> </div> <div class="form-group"> <label for="appMax">最大值</label> <input type="number" class="form-control" name="appMax" [(ngModel)]="model.appMax" #appMax="ngModel" [max]="10" /> <p [hidden]="appMax.valid||appMax.pristine">最小值10</p> </div> <div class="form-group"> <label for="appLt">小於</label> <input type="number" class="form-control" name="appLt" [(ngModel)]="model.appLt" #appLt="ngModel" [lt]="10" /> <p [hidden]="appLt.valid||appLt.pristine">值小於10</p> </div> <div class="form-group"> <label for="appLte">小於等於</label> <input type="number" class="form-control" name="appLte" [(ngModel)]="model.appLte" #appLte="ngModel" [lte]="10" /> <p [hidden]="appLte.valid||appLte.pristine">值小於等於10</p> </div> <div class="form-group"> <label for="appRange">取值範圍</label> <input type="number" class="form-control" name="appRange" [(ngModel)]="model.appRange" #appRange="ngModel" [range]="[10, 20]" /> <p [hidden]="appRange.valid||appRange.pristine">取值大於等於10到小於等於20</p> </div> <div class="form-group"> <label for="appDigits">數字</label> <input type="text" class="form-control" name="appDigits" [(ngModel)]="model.appDigits" #appDigits="ngModel" digits /> <p [hidden]="appDigits.valid||appDigits.pristine">必須是uint</p> </div> <div class="form-group"> <label for="appNumber">數字</label> <input type="text" class="form-control" name="appNumber" [(ngModel)]="model.appNumber" #appNumber="ngModel" number /> <p [hidden]="appNumber.valid||appNumber.pristine">任何數字</p> </div> <div class="form-group"> <label for="appUrl">鏈接</label> <input type="text" class="form-control" name="appUrl" [(ngModel)]="model.appUrl" #appUrl="ngModel" url /> <p [hidden]="appUrl.valid||appUrl.pristine">合法的url</p> </div> <div class="form-group"> <label for="appEmail">郵箱</label> <input type="text" class="form-control" name="appEmail" [(ngModel)]="model.appEmail" #appEmail="ngModel" email /> <p [hidden]="appEmail.valid||appEmail.pristine">合法的郵箱地址</p> </div> <div class="form-group"> <label for="appDate">日期</label> <input type="text" class="form-control" name="appDate" [(ngModel)]="model.appDate" #appDate="ngModel" date /> <p [hidden]="appDate.valid||appDate.pristine">合法的日期</p> </div> <div class="form-group"> <label for="appUuid">uuid</label> <input type="text" class="form-control" name="appUuid" [(ngModel)]="model.appUuid" #appUuid="ngModel" uuid="'all'" /> <p [hidden]="appUuid.valid||appUuid.pristine">不是合法的uuid</p> </div> <div class="form-group"> <label for="appPhone">電話</label> <input type="text" class="form-control" name="appPhone" [(ngModel)]="model.appPhone" #appPhone="ngModel" phone="CN" /> <p [hidden]="appPhone.valid||appPhone.pristine">不是合法的電話號碼</p> </div> <div class="form-group"> <label >兩次相同</label> <input class="form-control" type="password" ngModel name="appPassword" #appPassword="ngModel" required/> <p [hidden]="appPassword.valid||appPassword.pristine">必填項</p> <input class="form-control" type="password" ngModel name="appCertainPassword" #appCertainPassword="ngModel" [equalTo]="appPassword"/> <p [hidden]="appCertainPassword.valid||appCertainPassword.pristine">兩次輸入不一致</p> </div> <div class="form-group"> <label for="appEqual">相同</label> <input type="text" class="form-control" name="appEqual" [(ngModel)]="model.appEqual" #appEqual="ngModel" [equal]="'哈哈'" /> <p [hidden]="appEqual.valid||appEqual.pristine">與值不相符</p> </div> <div class="form-group"> <label for="appComplex">複合條件</label> <input type="number" class="form-control" name="appComplex" [(ngModel)]="model.appComplex" #appComplex="ngModel" [gte]="5" [max]="10" /> <p [hidden]="appComplex.valid||appComplex.pristine">大於等於5,最大是10</p> </div> <button type="submit" [disabled]="!validationForm.form.valid" class="btn btn-default">Submit</button> </form> </div>View Code
ts文件不需要做什麼,所以就不貼了。
模型驅動
app-model-driven.component.ts
import { Component, OnInit } from '@angular/core'; import { FormGroup, FormControl, Validators } from "@angular/forms"; import { CustomValidators } from 'ng2-validation'; @Component({ selector: 'app-app-model-driven', templateUrl: './app-model-driven.component.html', styleUrls: ['./app-model-driven.component.css'] }) export class AppModelDrivenComponent implements OnInit { public formGroup: FormGroup; password:string=""; constructor() { let password = new FormControl('', [Validators.required]); let certainPassword = new FormControl('', CustomValidators.equalTo(password)); this.formGroup = new FormGroup({ field: new FormControl('', CustomValidators.rangeLength([5, 9])), appGt:new FormControl('', CustomValidators.gt(10)), password:password, certainPassword:certainPassword, maxField:new FormControl('',[CustomValidators.gt(10),CustomValidators.max(20)]) }); } ngOnInit() { } onSubmit(){} }View Code
app-model-driven.component.html
<div class="container"> <form [formGroup]="formGroup" (ngSubmit)="onSubmit()" #validationForm2="ngForm" > <div class="form-group" > <input class="form-control" name="field" type="text" formControlName="field"/> <p *ngIf="validationForm2.form.controls.field.errors?.rangeLength">長度在5到9之間</p> <p>{{validationForm2.form.controls.field.errors?.rangeLength}}</p> </div> <div class="form-group" > <input class="form-control" name="appGt" type="number" formControlName="appGt"/> <p *ngIf="validationForm2.form.controls.appGt.errors?.gt">大於10</p> </div> <div class="form-group" > <input class="form-control" name="password" type="password" [(ngModel)]="password" formControlName="password"/> <p *ngIf="validationForm2.form.controls.password.errors?.required">必填</p> <p>{{test.pristine}}</p> <input class="form-control" type="password" formControlName="certainPassword"/> <p *ngIf="validationForm2.form.controls.certainPassword.errors?.equalTo">兩次相同</p> </div> <div class="form-group" > <label for="appMin">組合形式</label> <input type="number" class="form-control" name="appMin" formControlName="maxField" /> <p [hidden]="!validationForm2.form.controls.maxField.errors?.max &&!validationForm2.form.controls.maxField.errors?.gt">取值大於等於10且小於20</p> </div> <button type="submit" [disabled]="!validationForm2.form.valid" class="btn btn-default">Submit</button> </form> </div>View Code