欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular實(shí)現(xiàn)響應(yīng)式表單

 更新時(shí)間:2017年08月04日 09:12:19   作者:1CSH1  
本篇文章主要介紹了Angular實(shí)現(xiàn)響應(yīng)式表單,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

介紹

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>

GitHub 代碼

參考文章

Reactive Forms

效果圖


以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • angular實(shí)現(xiàn)form驗(yàn)證實(shí)例代碼

    angular實(shí)現(xiàn)form驗(yàn)證實(shí)例代碼

    本篇文章主要介紹了angular實(shí)現(xiàn)form驗(yàn)證實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。
    2017-01-01
  • AngularJS 2.0入門權(quán)威指南

    AngularJS 2.0入門權(quán)威指南

    這篇文章主要介紹了AngularJS 2.0入門權(quán)威指南的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-10-10
  • Angular 輸入框?qū)崿F(xiàn)自定義驗(yàn)證功能

    Angular 輸入框?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指南)

    這篇文章主要介紹了詳解使用angular框架離線你的應(yīng)用(pwa指南),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-01-01
  • 在 Angular 中使用懶加載路由的方法

    在 Angular 中使用懶加載路由的方法

    延遲加載是一種限制加載用戶當(dāng)前需要的模塊的方法,這可以提高應(yīng)用程序的性能并減小初始捆綁包大小,在本文中,您學(xué)習(xí)了如何在 Angular 應(yīng)用程序中使用惰性加載路由,本文分步驟講解的非常詳細(xì),感興趣的朋友一起看看吧
    2024-02-02
  • AngularJS 過濾器的簡單實(shí)例

    AngularJS 過濾器的簡單實(shí)例

    本文主要介紹AngularJS 過濾器,這里提供詳細(xì)了AngularJS 過濾器詳細(xì)資料,并提供簡單實(shí)例,有需要的朋友可以參考下
    2016-07-07
  • js常用正則表達(dá)式集錦

    js常用正則表達(dá)式集錦

    這篇文章主要介紹了js常用正則表達(dá)式集錦,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • AngularJs  Using $location詳解及示例代碼

    AngularJs Using $location詳解及示例代碼

    本文主要介紹AngularJs Using $location的知識資料,這里整理了相關(guān)的資料,及簡單示例代碼,有興趣的小伙伴可以參考下
    2016-09-09
  • Angular動畫實(shí)現(xiàn)的2種方式以及添加購物車動畫實(shí)例代碼

    Angular動畫實(shí)現(xiàn)的2種方式以及添加購物車動畫實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于Angular動畫的2種方式以及添加購物車動畫的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-08-08
  • Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output詳解(下)

    Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output詳解(下)

    這篇文章主要給大家介紹了關(guān)于Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。
    2017-07-07

最新評論