Angular6 form表單相關(guān)

一梆掸、form中使用的input, select等均不建議使用ngModel綁定變量,因為Angular7會移除form中的這個指令,如果在6中使用則會報警告熟妓,直接使用formControl或者formControlName綁定form即可盯桦,如下

<form [formGroup]="targetForm" (ngSubmit)="save()" onkeypress="if(event.keyCode==13||event.which==13){return false;}">
  <div>
    <label>
      姓名
    </label>
    <mat-form-field [floatLabel]="'never'">
      <input matInput autocomplete="username" disableautocomplete type="text" name="username" formControlName="username" required>
    </mat-form-field>
  </div>
  <div>
    <button mat-button type="submit" class="sure">保存</button>
  </div>
</form>

ts文件中targetForm定義如下:

  targetForm
  constructor(private fb: FormBuilder) {
    this.targetForm = this.fb.group({
      userName: ['王XX', Validators.required],
    })
  }

提交表單的時候慈俯,可以直接從剛剛定義的targetForm中取到value值,然后對應(yīng)提交

二拥峦、FormControl,FormGroup和FormArray

1贴膘、三者中FormControl屬于子元素,F(xiàn)ormGroup和FormArray可任意嵌套這三個元素
(1)FormGroup中嵌套FromControl略号。這是最常見的形式刑峡,上述示例中就是這種格式
(2)FormGroup中嵌套FormGroup洋闽。
這種格式一般是表單中某些項和某一項有關(guān)聯(lián)關(guān)系時使用,可以通過addControl來動態(tài)添加突梦,舉個栗子:
html

<form [formGroup]="targetForm" (ngSubmit)="save()" onkeypress="if(event.keyCode==13||event.which==13){return false;}">
  <div>
    <label>
      職業(yè)
    </label>
    <mat-form-field [floatLabel]="'never'" class="dialog-input">
      <mat-select placeholder="請選擇" formControlName="profession"
                  (selectionChange)="changeProfession($event)" required>
        <mat-option *ngFor="let item of professions" [value]="item">
          {{ item }}
        </mat-option>
      </mat-select>
    </mat-form-field>
  </div>
  <div *ngIf="targetForm.get('profession').value === 'teacher'" formGroupName="teacher">
    <div>
      <label>
        學(xué)校
      </label>
      <mat-form-field [floatLabel]="'never'">
        <input matInput autocomplete="school" disableautocomplete type="text" name="school" formControlName="school" required>
      </mat-form-field>
    </div>
    <div>
      <label>
        年級
      </label>
      <mat-form-field [floatLabel]="'never'">
        <input matInput autocomplete="grade" disableautocomplete type="text" name="grade" formControlName="grade" required>
      </mat-form-field>
    </div>
  </div>
  <div>
    <button mat-button type="submit" class="sure">保存</button>
  </div>
</form>

ts诫舅,當選擇職業(yè)為teacher時

  constructor(private fb: FormBuilder){}
  this.targetForm = fb.group({
    profession: ['', Validators.required],
  })
  changeProfession(event) {
    const {value} = event
    if(value === 'teacher') {
      const fbGroup = this.fb.group({
        school: ['xxx', Validators.required],
        grade: ['', Validators.required]
      })
      // contains方法判斷是否包含teacher control
      if(!this.targetForm.contains('teacher')) {
        this.targetForm.addControl('teacher', fbGroup)
      }
    } else{
      // 刪除targetForm中的teacher control
      this.targetForm.removeControl('teacher')
    }
  }

(3)FormGroup中嵌套FormArray,且FormArray中嵌套FormGroup阳似。一般用于對表單中數(shù)組的動態(tài)處理骚勘,舉個栗子:
html文件

 <div>
    <label>
      職業(yè)
    </label>
    <mat-form-field [floatLabel]="'never'" class="dialog-input">
          <mat-select placeholder="請選擇" formControlName="profession" 
(selectionChange)="changeProfession($event)" required>
            <mat-option *ngFor="let item of professions" [value]="item">
              {{ item }}
            </mat-option>
          </mat-select>
      </mat-form-field>
  </div>
  <ng-container  *ngIf="targetForm.get('profession').value === 'teacher'">
  <mat-icon style="color: #3CB371" (click)="addAction()">add</mat-icon>
<div formArrayName="testArr">
  <ng-container *ngFor="let test of testArr.controls;let index = index" [formGroupName]="i">
    <div class="col-5">
      <mat-form-field class="w-100">
        <mat-form-field class="w-100">
          <input autocomplete="off" disableautocomplete matInput type="text" formControlName="key" placeholder="key">
        </mat-form-field>
      </mat-form-field>
    </div>
    <div class="col-5">
      <mat-form-field class="w-100">
        <input autocomplete="off" disableautocomplete matInput type="text" formControlName="value" placeholder="value">
      </mat-form-field>
    </div>
    <div class="m-auto text-right">
      <mat-icon style="color: #3CB371" class="cancelMatIcon" (click)="removeAction(index)">
        delete
      </mat-icon>
    </div>
  </ng-container >
</div>
</ng-container>

ts文件

 constructor(private fb: FormBuilder){
    this.targetForm = fb.group({
      profession: ['', Validators.required],
      testArr: fb.array([])
    })
  }
get testArr() {
  return this.targetForm.get('testArr') as FormArray
}
// 新增
addAction() {
    const fb = this.fb
    const fbGroup = fb.group({
        key: ['', Validators.required],
        value: ['', Validators.required],
    })
    this.targetForm.controls.testArr.push(fbGroup)
}

// 刪除
removeAction(index) {
    const arr = this.targetForm.get('testArr') as FormArray
    arr.removeAt(index)
}

三、表單中常見的坑

  1. 表單中的input框回車就自動提交表單
    解決方法撮奏,在<form>標簽上添加onkeypress="if(event.keyCode===13||event.which===13){return false;}"

  2. 表單中的button標簽俏讹,如果不設(shè)置type,點擊默認觸發(fā)點擊事件畜吊,除了提交按鈕設(shè)置type='submit'泽疆,其他button需要設(shè)置type='button'屬性

  3. formGroup里面嵌套formGroup,點擊提交的時候外層的能觸發(fā)驗證玲献,但是內(nèi)層的不能觸發(fā)驗證殉疼。解決方法:[formGroup] = "targetForm.controls['test']"改為formGroupName="test"

  4. 谷歌瀏覽器中,當input type=text與type=password相鄰時捌年,input框會自動填充用戶名瓢娜。解決方法為:設(shè)置兩個form將兩個input隔離開。如下:

<form>
    <input type="text"/>
</form>
<form>
    <input type="password"/>
</form>
  1. formGroup中嵌套的formArray,formArray中嵌套formGroup礼预,submit的時候眠砾,判斷this.targetForm.valid時,formArray內(nèi)部若不能校驗托酸,則需要查詢formArray用法是否有問題褒颈,需要設(shè)置formArrayName="testArr",且子元素需要設(shè)置formGroupName = 'i'励堡,形如上栗(3)谷丸;若formArray中是formControl,則子元素直接設(shè)置formControlName = 'i' 就可以了

6应结、開發(fā)項目時遇到一個問題刨疼,form中嵌套組件,組件中[formGroup]和父組件是同一個鹅龄,通過將父組件中的formGroup傳進去币狠,從而來實時變更form。組件中屬性是級聯(lián)關(guān)系且必填砾层,發(fā)現(xiàn)提交表單時子組件若未填寫漩绵,并沒有觸發(fā)表單驗證,通過嘗試發(fā)現(xiàn)可通過將formGroup中的子組件的formControl調(diào)用markAsTouched()方法來出發(fā)驗證肛炮。

7止吐、動態(tài)隱藏或新增表單中的某些必填formControl有時會造成新增后修改該屬性宝踪,值改了但是頁面沒有對應(yīng)更新。我們可以不刪除碍扔,隱藏時僅需設(shè)置這些屬性為非必填瘩燥,開放時設(shè)置為必填即可,設(shè)置代碼如下

  addValidators(targetForm, attributes, validators) {
    attributes.forEach(it => {
      if (targetForm.get(it)) {
        targetForm.get(it).setValidators(validators)
      }
    })
  }

  clearValidators(targetForm, attributes) {
    attributes.forEach(it => {
      if (targetForm.get(it)) {
        targetForm.get(it).clearValidators()
        targetForm.get(it).updateValueAndValidity({onlySelf: true})
      }
    })
  }

8不同、表單中屬性設(shè)置disabled后厉膀,通過form.value將獲取不到該值,可通過form.getRawValue()獲取表單值

9二拐、切記組件中的input字段名不可和公用指令名重名服鹅,不然會同時作為指令作用在組件上,剛吃過這個虧emmm....

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末百新,一起剝皮案震驚了整個濱河市企软,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌饭望,老刑警劉巖仗哨,帶你破解...
    沈念sama閱讀 211,948評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異铅辞,居然都是意外死亡厌漂,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評論 3 385
  • 文/潘曉璐 我一進店門斟珊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來桩卵,“玉大人,你說我怎么就攤上這事倍宾。” “怎么了胜嗓?”我有些...
    開封第一講書人閱讀 157,490評論 0 348
  • 文/不壞的土叔 我叫張陵高职,是天一觀的道長。 經(jīng)常有香客問我辞州,道長怔锌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,521評論 1 284
  • 正文 為了忘掉前任变过,我火速辦了婚禮埃元,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘媚狰。我一直安慰自己岛杀,他們只是感情好,可當我...
    茶點故事閱讀 65,627評論 6 386
  • 文/花漫 我一把揭開白布崭孤。 她就那樣靜靜地躺著类嗤,像睡著了一般糊肠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上遗锣,一...
    開封第一講書人閱讀 49,842評論 1 290
  • 那天货裹,我揣著相機與錄音,去河邊找鬼精偿。 笑死弧圆,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的笔咽。 我是一名探鬼主播搔预,決...
    沈念sama閱讀 38,997評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼拓轻!你這毒婦竟也來了斯撮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,741評論 0 268
  • 序言:老撾萬榮一對情侶失蹤扶叉,失蹤者是張志新(化名)和其女友劉穎勿锅,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體枣氧,經(jīng)...
    沈念sama閱讀 44,203評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡溢十,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,534評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了达吞。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片张弛。...
    茶點故事閱讀 38,673評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖酪劫,靈堂內(nèi)的尸體忽然破棺而出吞鸭,到底是詐尸還是另有隱情,我是刑警寧澤覆糟,帶...
    沈念sama閱讀 34,339評論 4 330
  • 正文 年R本政府宣布刻剥,位于F島的核電站,受9級特大地震影響滩字,放射性物質(zhì)發(fā)生泄漏造虏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,955評論 3 313
  • 文/蒙蒙 一麦箍、第九天 我趴在偏房一處隱蔽的房頂上張望漓藕。 院中可真熱鬧,春花似錦挟裂、人聲如沸享钞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嫩与。三九已至寝姿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間划滋,已是汗流浹背饵筑。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留处坪,地道東北人根资。 一個月前我還...
    沈念sama閱讀 46,394評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像同窘,于是被迫代替她去往敵國和親玄帕。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,562評論 2 349

推薦閱讀更多精彩內(nèi)容

  • 本人做php的,最近發(fā)現(xiàn)JS真的是博大精深啊,比PHP難.在HTML中想邦,表單是由form元素來表示的裤纹,但是在jav...
    linfree閱讀 2,140評論 3 17
  • ??JavaScript 最初的一個應(yīng)用鹰椒,就是分擔服務(wù)器處理表單的責任,打破處處依賴服務(wù)器的局面呕童。 ??盡管目前的...
    霜天曉閱讀 659評論 0 3
  • ??JavaScript 與 HTML 之間的交互是通過事件實現(xiàn)的夺饲。 ??事件奸汇,就是文檔或瀏覽器窗口中發(fā)生的一些特...
    霜天曉閱讀 3,477評論 1 11
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標準往声。 注意:講述HT...
    kismetajun閱讀 27,449評論 1 45
  • 感恩執(zhí)行師課堂遇見的所有小伙伴擂找,三個月的時間與你們同哭同笑同行同居,每一個人都是那么卓越浩销,讓人感覺非常的舒服贯涎。因為...
    祺予閱讀 408評論 0 5