成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

angular6的響應(yīng)式表單

MycLambert / 2901人閱讀

摘要:在模塊里面引入要使用響應(yīng)式表單,就要從包中導(dǎo)入,并把它添加到你的的數(shù)組中。導(dǎo)入驗(yàn)證器函數(shù)響應(yīng)式表單包含了一組開(kāi)箱即用的常用驗(yàn)證器函數(shù)。這些驗(yàn)證器屬性可以和響應(yīng)式表單提供的內(nèi)置驗(yàn)證器組合使用。

1:在AppModule模塊里面引入 ReactiveFormsModule

要使用響應(yīng)式表單,就要從@angular/forms包中導(dǎo)入ReactiveFormsModule,并把它添加到你的NgModule的imports數(shù)組中。

import { ReactiveFormsModule } from "@angular/forms";

@NgModule({
  imports: [
    // other imports ...
    ReactiveFormsModule
  ],
})
export class AppModule { }

2:創(chuàng)建一個(gè)新的組件

 ng g c NameEditor

3:請(qǐng)?jiān)诮M件中導(dǎo)入 FormControl 類(lèi)

FormControl類(lèi)是angular響應(yīng)式表單最基本的構(gòu)造快,要注冊(cè)單個(gè)的表單控件,請(qǐng)?jiān)诮M件中導(dǎo)入FormControl類(lèi),并創(chuàng)建一個(gè)FormControl的新實(shí)例,把它保存在某個(gè)屬性里面。
import { Component } from "@angular/core";
import { FormControl } from "@angular/forms";

@Component({
  selector: "app-name-editor",
  templateUrl: "./name-editor.component.html",
  styleUrls: ["./name-editor.component.css"]
})

export class NameEditorComponent {
  name = new FormControl("");
}    

4:在組件的模板中注冊(cè)一個(gè)表單控件

修改模板,為表單控件添加 formControl 綁定,formControl 是由 ReactiveFormsModule 中的 FormControlDirective 提供的。


Value: {{ name.value }}

使用這種模板綁定語(yǔ)法,把該表單控件注冊(cè)給了模板中名為 name 的輸入元素。這樣,表單控件和 DOM
元素就可以互相通訊了:視圖會(huì)反映模型的變化,模型也會(huì)反映視圖中的變化。

5:替換表單控件的值

FormControl 提供了一個(gè)setValue()方法,他會(huì)修改這個(gè)表單控件的值。

js

 updateName() {
      this.name.setValue("Nancy");
 }

html


Value:{{name.value}}

在這個(gè)例子中,你只使用單個(gè)控件FormControl,但是當(dāng)調(diào)用 FormGroup 或 FormArray 的 setValue()
方法時(shí),傳入的值就必須匹配控件組或控件數(shù)組的結(jié)構(gòu)才行

6:把表單控件分組

FormControl的實(shí)例能控制單個(gè)輸入框所對(duì)應(yīng)的控件,F(xiàn)ormGroup可以控制一組FormControl實(shí)例的表單狀態(tài),當(dāng)創(chuàng)建FormGroup時(shí),其中的每一個(gè)控件都會(huì)根據(jù)名字進(jìn)行跟蹤

1>:創(chuàng)建新的組件

 ng g c ProfileEditor

2>:導(dǎo)入 FormGroup 和 FormControl 類(lèi)并且創(chuàng)建 FormGroup實(shí)例

import { Component } from "@angular/core";
import { FormGroup, FormControl } from "@angular/forms";
 
@Component({
  selector: "app-profile-editor",
  templateUrl: "./profile-editor.component.html",
  styleUrls: ["./profile-editor.component.css"]
})

export class ProfileEditorComponent {
  profileForm = new FormGroup({
    firstName: new FormControl(""),
    lastName: new FormControl(""),
  });
}
現(xiàn)在這些多帶帶的控件FormControl被收集到了一個(gè)控件組中FormGroup, FormGroup 實(shí)例擁有和 FormControl 實(shí)例相同的屬性(比如 value、untouched)和方法(比如 setValue())。

3>:關(guān)聯(lián)FormGroup的模型和視圖

FormGroup能追蹤每個(gè)多帶帶控件FormControl的狀態(tài)和變化,如果其中某個(gè)控件的狀態(tài)或值變化了,父控件也會(huì)一次新的狀態(tài)變更或值變更事件

profileForm通過(guò)[formGroup]指令綁定到了 form
元素,在該模型和表單中的輸入框之間創(chuàng)建了一個(gè)通訊層,F(xiàn)ormControlName 指令提供的 formControlName 屬性把每個(gè)輸入框和 FormGroup 中定義的表單控件綁定起來(lái)。

4>:關(guān)聯(lián)FormGroup的模型和視圖

html

  

js

onSubmit () {
    console.warn(this.profileForm.value);
}
form 標(biāo)簽所發(fā)出的 submit 事件是原生 DOM 事件,通過(guò)點(diǎn)擊類(lèi)型為 submit 的按鈕可以觸發(fā)本事件

6:嵌套的表單組

js

profileForm = new FormGroup({
    firstName: new FormControl(""),
    lastName: new FormControl(""),
    address: new FormGroup({
      street: new FormControl(""),
      city: new FormControl(""),
      state: new FormControl(""),
      zip: new FormControl("")
    })
});

html

部分模型修改

html


js

updateProfile() {
      this.profileForm.patchValue({
        firstName: "Nancy",
        address: {
          street: "123 Drew Street"
        }
      });
}
patchValue() 方法要針對(duì)模型的結(jié)構(gòu)進(jìn)行更新。patchValue() 只會(huì)更新表單模型中所定義的那些屬性。

6:使用 FormBuilder 來(lái)生成表單控件

FormBuilder 服務(wù)提供了一些便捷方法來(lái)生成表單控件。
FormBuilder在幕后也使用同樣的方式來(lái)創(chuàng)建和返回這些實(shí)例,只是用起來(lái)更簡(jiǎn)單。 下面會(huì)重構(gòu) ProfileEditor 組件,用FormBuilder 來(lái)代替手工創(chuàng)建這些 FormControl 和 FormGroup。

Step 1 - 導(dǎo)入 FormBuilder 類(lèi)

import { FormBuilder } from "@angular/forms";

Step 2 - 注入FormBuild 服務(wù)

constructor(private fb: FormBuilder) { }

Step 3- 生成表單控件

FormBuilder 服務(wù)有三個(gè)方法:control()、group() 和 array()。這些方法都是工廠(chǎng)方法,用于在組件類(lèi)中分別生成
FormControl、FormGroup 和 FormArray。

你可以使用 group() 方法,用和前面一樣的名字來(lái)定義這些屬性。這里,每個(gè)控件名對(duì)應(yīng)的值都是一個(gè)數(shù)組,這個(gè)數(shù)組中的第一項(xiàng)是其初始值。你可以只使用初始值來(lái)定義控件,但是如果你的控件還需要同步或異步驗(yàn)證器,那就在這個(gè)數(shù)組中的第二項(xiàng)和第三項(xiàng)提供同步和異步驗(yàn)證器。

import { Component } from "@angular/core";
import { FormBuilder } from "@angular/forms";
 
@Component({
  selector: "app-profile-editor",
  templateUrl: "./profile-editor.component.html",
  styleUrls: ["./profile-editor.component.css"]
})
export class ProfileEditorComponent {
  profileForm = this.fb.group({
    firstName: ["張"],
    lastName: ["娉"],
    address: this.fb.group({
      street: [""],
      city: [""],
      state: [""],
      zip: [""]
    }),
  });
 
  constructor(private fb: FormBuilder) { }
}

7:簡(jiǎn)單的表單驗(yàn)證

如何把單個(gè)驗(yàn)證器添加到表單控件中,以及如何顯示表單的整體狀態(tài)。

Step 1 - 導(dǎo)入驗(yàn)證器函數(shù)

import { Validators } from "@angular/forms";
響應(yīng)式表單包含了一組開(kāi)箱即用的常用驗(yàn)證器函數(shù)。這些函數(shù)接收一個(gè)控件,用以驗(yàn)證并根據(jù)驗(yàn)證結(jié)果返回一個(gè)錯(cuò)誤對(duì)象或空值。

Step 2 - 把字段設(shè)為必填

最常見(jiàn)的校驗(yàn)項(xiàng)是把一個(gè)字段設(shè)為必填項(xiàng)。本節(jié)描述如何為 firstName 控件添加“必填項(xiàng)”驗(yàn)證器。
在組件中,把靜態(tài)方法 Validators.required 設(shè)置為 firstName 控件值數(shù)組中的第二項(xiàng)。
profileForm = this.fb.group({
  firstName: ["", Validators.required],
  lastName: [""],
  address: this.fb.group({
    street: [""],
    city: [""],
    state: [""],
    zip: [""]
  }),
});
HTML5 有一組內(nèi)置的屬性,用來(lái)進(jìn)行原生驗(yàn)證,包括 required、minlength、maxlength等。雖然是可選的,不過(guò)你也可以在表單的輸入元素上把它們添加為附加屬性來(lái)使用它們。這里我們把 required 屬性添加到 firstName
輸入元素上。

這些 HTML5 驗(yàn)證器屬性可以和 Angular
響應(yīng)式表單提供的內(nèi)置驗(yàn)證器組合使用。組合使用這兩種驗(yàn)證器實(shí)踐,可以防止在模板檢查完之后表達(dá)式再次被修改導(dǎo)致的錯(cuò)誤。

8:顯示表單的狀態(tài)

現(xiàn)在,你已經(jīng)往表單控件上添加了一個(gè)必填字段,它的初始值是無(wú)效的(invalid)。這種無(wú)效狀態(tài)冒泡到其父 FormGroup 中,也讓這個(gè) FormGroup 的狀態(tài)變?yōu)闊o(wú)效的。你可以通過(guò)該 FormGroup 實(shí)例的 status 屬性來(lái)訪(fǎng)問(wèn)其當(dāng)前狀態(tài)。

Form Status: {{ profileForm.status }}

9:使用表單數(shù)組管理動(dòng)態(tài)控件

FormArray 是 FormGroup 之外的另一個(gè)選擇,用于管理任意數(shù)量的匿名控件,如果你事先不知道子控件的數(shù)量,F(xiàn)ormArray是一個(gè)很好的選擇

Step 1 - 導(dǎo)入 FormArray

import { FormArray } from "@angular/forms";

Step 2 - 定義 FormArray

為 profileForm 添加一個(gè) aliases 屬性,把它定義為 FormArray 類(lèi)型。(FormBuilder 服務(wù)用于創(chuàng)建 FormArray 實(shí)例。)
profileForm = this.fb.group({
   firstName: ["張", Validators.required],
    lastName: ["以"],
    address: this.fb.group({
      street: [""],
      city: [""],
      state: [""],
      zip: [""]
    }),
    aliases: this.fb.array([
      this.fb.control("")
    ])
  });

Step 3 - 訪(fǎng)問(wèn)FormArray控件

通過(guò) getter 來(lái)訪(fǎng)問(wèn)控件比較便捷,也容易復(fù)用
使用 getter 語(yǔ)法來(lái)創(chuàng)建一個(gè)名為 aliases 的類(lèi)屬性
get aliases() {
 
}
從父控件 FormGroup 中接收綽號(hào)的 FormArray 控件。
get aliases() {
  return this.profileForm.get("aliases") as FormArray;
}
addAlias() {
  this.aliases.push(this.fb.control(""));
}

Step 3 - 在模板中顯示表單數(shù)組

在模型中定義了 aliases 的 FormArray 之后,你必須把它加入到模板中供用戶(hù)輸入,使用 formArrayName 在這個(gè)
FormArray 和模板之間建立綁定。

Aliases

每當(dāng)新的 alias 加進(jìn)來(lái)時(shí),F(xiàn)ormArray 就會(huì)基于這個(gè)索引號(hào)提供它的控件。這將允許你在每次計(jì)算根控件的狀態(tài)和值時(shí)跟蹤每個(gè)控件。

全部代碼

html

Address

Aliases

Form Status: {{ profileForm.status }}

js

import { Component, OnInit } from "@angular/core";
import {FormControl, FormGroup, FormBuilder, Validators, FormArray} from "@angular/forms";

@Component({
  selector: "app-profile-editor",
  templateUrl: "./profile-editor.component.html",
  styleUrls: ["./profile-editor.component.css"]
})
export class ProfileEditorComponent implements OnInit {
  profileForm = this.fb.group({
   firstName: ["張", Validators.required],
    lastName: ["以"],
    address: this.fb.group({
      street: [""],
      city: [""],
      state: [""],
      zip: [""]
    }),
    aliases: this.fb.array([
      this.fb.control("")
    ])
  });
  constructor(private fb: FormBuilder) {

  }

  ngOnInit() {
  }

  onSubmit () {
    console.warn(this.profileForm.value);
  }
  
  updateProfile() {
    this.profileForm.patchValue({
      firstName: "Nancy",
      address: {
        street: "123 Drew Street"
      }
    });
  }
  get aliases () {
    return this.profileForm.get("aliases") as FormArray;
  }
  addAlias() {
    this.aliases.push(this.fb.control(""));
  }
}

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/98208.html

相關(guān)文章

  • angular6響應(yīng)表單

    摘要:在模塊里面引入要使用響應(yīng)式表單,就要從包中導(dǎo)入,并把它添加到你的的數(shù)組中。導(dǎo)入驗(yàn)證器函數(shù)響應(yīng)式表單包含了一組開(kāi)箱即用的常用驗(yàn)證器函數(shù)。這些驗(yàn)證器屬性可以和響應(yīng)式表單提供的內(nèi)置驗(yàn)證器組合使用。 1:在AppModule模塊里面引入 ReactiveFormsModule 要使用響應(yīng)式表單,就要從@angular/forms包中導(dǎo)入ReactiveFormsModule,并把它添加到你的N...

    alogy 評(píng)論0 收藏0
  • angular6響應(yīng)表單

    摘要:在模塊里面引入要使用響應(yīng)式表單,就要從包中導(dǎo)入,并把它添加到你的的數(shù)組中。導(dǎo)入驗(yàn)證器函數(shù)響應(yīng)式表單包含了一組開(kāi)箱即用的常用驗(yàn)證器函數(shù)。這些驗(yàn)證器屬性可以和響應(yīng)式表單提供的內(nèi)置驗(yàn)證器組合使用。 1:在AppModule模塊里面引入 ReactiveFormsModule 要使用響應(yīng)式表單,就要從@angular/forms包中導(dǎo)入ReactiveFormsModule,并把它添加到你的N...

    hzc 評(píng)論0 收藏0
  • 【CuteJavaScript】Angular6入門(mén)項(xiàng)目(3.編寫(xiě)服務(wù)和引入RxJS)

    摘要:發(fā)布通過(guò)回調(diào)方法向發(fā)布事件。觀察者一個(gè)回調(diào)函數(shù)的集合,它知道如何去監(jiān)聽(tīng)由提供的值。 本文目錄 一、項(xiàng)目起步 二、編寫(xiě)路由組件 三、編寫(xiě)頁(yè)面組件 1.編寫(xiě)單一組件 2.模擬數(shù)據(jù) 3.編寫(xiě)主從組件 四、編寫(xiě)服務(wù) 1.為什么需要服務(wù) 2.編寫(xiě)服務(wù) 五、引入RxJS 1.關(guān)于RxJS 2.引入RxJS 3.改造數(shù)據(jù)獲取方式 六、改造組件 1.添...

    RebeccaZhong 評(píng)論0 收藏0
  • 初探Angular6.x---用戶(hù)列表與用戶(hù)詳情

    摘要:初探用戶(hù)列表與用戶(hù)詳情在上一篇博文進(jìn)入用戶(hù)編輯中我們分享了屬性名稱(chēng)和這兩個(gè)表達(dá)式的運(yùn)用我們已經(jīng)可以將表單里的修改與我們展示出來(lái)的值進(jìn)行同步今天我們來(lái)學(xué)習(xí)在中如何展示一個(gè)列表在項(xiàng)目里列表展示可以說(shuō)是非常普遍的一個(gè)需求了幾乎有展示數(shù)   初探Angular6.x---用戶(hù)列表與用戶(hù)詳情   在上一篇博文《Angular6.x---進(jìn)入用戶(hù)編輯》中,我們分享了{(lán){屬性名稱(chēng)}}和[(ngMod...

    helloworldcoding 評(píng)論0 收藏0
  • angular6 自定義組件,實(shí)現(xiàn)雙向數(shù)據(jù)綁定

    摘要:在編寫(xiě)組件之前,首先看一下組件的使用方式和效果其中標(biāo)簽是自定義組件,利用符號(hào)進(jìn)行雙向綁定,下面標(biāo)簽顯示所綁定的值。 在包裝輸入類(lèi)型的組件時(shí),我們需要向外暴露數(shù)據(jù)接口,用戶(hù)輸入和輸出,這時(shí)候在組件內(nèi)部定義雙向綁定,會(huì)大大方便用戶(hù)的使用。 在編寫(xiě)組件之前,首先看一下組件的使用方式和效果: app.component:{{testBinding}} 其中binding-test標(biāo)簽是自定義...

    Ajian 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<