Angular實(shí)現(xiàn)響應(yīng)式表單
介紹
Angular 總共提供了 3 中表單實(shí)現(xiàn)方式,分別是:Template-driven Forms (模板驅(qū)動表單) 、 Reactive Forms (響應(yīng)式表單) 、 Dynamic Forms (動態(tài)表單) 。本文只介紹響應(yīng)式表單。
響應(yīng)式表單是什么呢?其實(shí)跟我們以前用 JQuery 或者其他框架實(shí)現(xiàn)的思路差不多,就是使用 HTML 顯示數(shù)據(jù),然后通過定義一定的校驗(yàn)器、校驗(yàn)規(guī)則以及校驗(yàn)提示語,通過事件觸發(fā)校驗(yàn)后校驗(yàn)不通過的顯示提示語,只不過用了 Angular,我們就使用 Angular 提供的語法來實(shí)現(xiàn)這個(gè)校驗(yàn)過程。
使用
接下來我們通過代碼例子來介紹如何使用響應(yīng)式表單。
引入響應(yīng)式表單模塊
在我們要使用響應(yīng)式表單的那個(gè)模塊里面引入響應(yīng)式表單模塊,比如我們在文章模塊中使用響應(yīng)式表單,我們就要在 imports 中添加 ReactiveFormsModule。代碼如下
@NgModule({ imports: [ RouterModule, RouterModule.forChild(articleRoutes), SharedModule, ReactiveFormsModule, NgbModule.forRoot() ], declarations: [ HomeComponent, DetailComponent, CommentComponent, CommentViewComponent ], providers: [ HomeService, DetailService, CommentService ] }) export class ArticleModule { }
編寫校驗(yàn)器代碼
首先我們這里的表單有 3 個(gè)字段,分別是 nickname、email、content; nickname 添加必填校驗(yàn)器,email 添加必填和郵箱格式校驗(yàn)器,content添加必填校驗(yàn)器。
首先在 CommentComponent 中注入 FormBuilder 對象,并添加 commentForm 表單組以及創(chuàng)建一個(gè)評論對象 comment。
public commentForm: FormGroup; public comment: Comment = new Comment(); constructor(private formBuilder: FormBuilder){}
定義校驗(yàn)器的提示語 validationMessages, formErrors 是在模板中顯示的提示語,提示語來自 validationMessages
public formErrors = { "nickname": "", "email": "", "content": "", "formError": "" } public validationMessages = { "nickname": { "required": "昵稱不能為空", }, "email": { "required": "郵箱不能為空", "pattern": "請輸入正確的郵箱地址" }, "content": { "required": "內(nèi)容不能為空" } }
在組件啟動的函數(shù)中構(gòu)造表單,這時(shí)候?yàn)槊總€(gè)字段添加了校驗(yàn)器,并且綁定在什么時(shí)候觸發(fā)校驗(yàn),這里我們在每個(gè)值改變的時(shí)候觸發(fā)。
ngOnInit(): void { this.buildForm(); } private buildForm() { this.commentForm = this.formBuilder.group({ "nickname":[ this.comment.nickname, [ Validators.required ] ], "email": [ this.comment.email, [ Validators.required, Validators.pattern("^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$") ] ], "content": [ this.comment.content, [ Validators.required ] ] }); this.commentForm.valueChanges.subscribe(data => this.onValueChanged(data)); this.onValueChanged(); }
onValueChanged() 方法實(shí)現(xiàn)了判斷是那個(gè)字段校驗(yàn)不通過,然后將該字段的 validationMessages 提示語賦值給 formErrors,在模板那里有判斷如果 formErrors.email 等等字段不為空則顯示改內(nèi)容,也即是校驗(yàn)器的提示語
onValueChanged(data?: any) { if (!this.commentForm) { return; } const form = this.commentForm; for (const field in this.formErrors) { this.formErrors[field] = ''; const control = form.get(field); if (control && control.dirty && !control.valid) { const messages = this.validationMessages[field]; for (const key in control.errors) { this.formErrors[field] += messages[key] + ' '; } } } }
HTML 模板代碼
我們要關(guān)注的是 [formGroup]=”commentForm”、novalidate、formControlName=”nickname”、以及 *ngIf=”formErrors.nickname” 這幾個(gè)點(diǎn),并不是指具體的點(diǎn),而是著重看這些語法的每一個(gè)地方,在你自己實(shí)現(xiàn)的時(shí)候需要根據(jù)你的代碼修改的。
還有一個(gè)是 (ngSubmit)=”sendComment()” 定義了該表單點(diǎn)擊提交時(shí)調(diào)用的函數(shù)。
<form [formGroup]="commentForm" (ngSubmit)="sendComment()" role="form" novalidate> <div class="control-group"> <div class="form-group floating-label-form-group controls" [ngClass]="{'has-error': formErrors.nickname}"> <label>{{ 'comment.nickname' | translate }}</label> <input formControlName="nickname" type="text" class="form-control" placeholder="{{ 'comment.nickname' | translate }}"> <p *ngIf="formErrors.nickname" class="help-block text-danger"> {{ formErrors.nickname }} </p> </div> </div> <div class="control-group" > <div class="form-group floating-label-form-group controls" [ngClass]="{'has-error': formErrors.email}"> <label>{{ 'comment.email' | translate }}</label> <input formControlName="email" type="email" class="form-control" placeholder="{{ 'comment.email' | translate }}"> <p *ngIf="formErrors.email" class="help-block text-danger"> {{ formErrors.email }} </p> </div> </div> <div class="control-group"> <div class="form-group floating-label-form-group controls" [ngClass]="{'has-error': formErrors.content}"> <label>{{ 'comment.content' | translate }}</label> <textarea formControlName="content" rows="5" class="form-control" placeholder="{{ 'comment.content' | translate }}"></textarea> <p *ngIf="formErrors.content" class="help-block text-danger"> {{ formErrors.content }} </p> </div> </div> <p *ngIf="formErrors.formError" class="help-block text-danger"> {{ formErrors.formError }} </p> <br> <div id="success"></div> <div class="form-group"> <button [disabled]="commentForm.invalid" type="submit" class="btn btn-secondary" >{{ 'comment.submit' | translate }}</button> </div> </form>
參考文章
效果圖
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
angular實(shí)現(xiàn)form驗(yàn)證實(shí)例代碼
本篇文章主要介紹了angular實(shí)現(xiàn)form驗(yàn)證實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01Angular 輸入框?qū)崿F(xiàn)自定義驗(yàn)證功能
AngularJS 表單和控件可以驗(yàn)證輸入的數(shù)據(jù)。本文給大家介紹Angular 輸入框?qū)崿F(xiàn)自定義驗(yàn)證功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-02-02詳解使用angular框架離線你的應(yīng)用(pwa指南)
這篇文章主要介紹了詳解使用angular框架離線你的應(yīng)用(pwa指南),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01AngularJs Using $location詳解及示例代碼
本文主要介紹AngularJs Using $location的知識資料,這里整理了相關(guān)的資料,及簡單示例代碼,有興趣的小伙伴可以參考下2016-09-09Angular動畫實(shí)現(xiàn)的2種方式以及添加購物車動畫實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于Angular動畫的2種方式以及添加購物車動畫的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output詳解(下)
這篇文章主要給大家介紹了關(guān)于Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-07-07