2016-12-16 69 views
0

我學反應性動態形式在角2.如何反應性的在動態形式驗證消息中的角2

我想驗證等angular.io菜譜形式驗證確實消息。

事情是這樣的:

this.heroForm.valueChanges 
    .subscribe(data => this.onValueChanged(data)); 

所以我訂閱的形式valuechanges動態形式

,但奇怪的是發生的,是這樣的:

我從組的兩個addrees,一個是有效的,兩個是無效的。

所以錯誤信息應該是一個,但結果是兩個!

有人可以幫助解決這個問題嗎?

這裏是run file

下面是ADRESS HTML和TS文件

import { Component, Input } from '@angular/core'; 
 
import { FormGroup } from '@angular/forms'; 
 

 
@Component({ 
 
    moduleId: module.id, 
 
    selector: 'address', 
 
    templateUrl: 'address.component.html', 
 
}) 
 
export class AddressComponent { 
 
    @Input('group') 
 
    public adressForm: FormGroup; 
 
}
<div [formGroup]="adressForm"> 
 
    <div class="form-group col-xs-6"> 
 
     <label>street</label> 
 
     <input type="text" class="form-control" formControlName="street"> 
 
     <small [hidden]="adressForm.controls.street.valid" class="text-danger"> 
 
      Street is required 
 
     </small> 
 
    </div> 
 
    <div class="form-group col-xs-6"> 
 
     <label>postcode</label> 
 
     <input type="text" class="form-control" formControlName="postcode"> 
 
    </div> 
 
</div>

這裏是應用

import { Component, OnInit } from '@angular/core'; 
 
import { FormGroup, FormArray, FormBuilder, Validators } from '@angular/forms'; 
 
import { Customer } from '../model/customer.model'; 
 

 
@Component({ 
 
    selector: 'customer-component', 
 
    templateUrl: 'customer.component.html', 
 
}) 
 
export class CustomerComponent implements OnInit { 
 
    public customerForm: FormGroup; 
 

 
    constructor(private _fb: FormBuilder) { } 
 

 
    ngOnInit() { 
 
     this.customerForm = this._fb.group({ 
 
      'name': ['', [Validators.required, Validators.minLength(5)]], 
 
      'addresses': this._fb.array([]) 
 
     }); 
 

 
     // add address 
 
     this.addAddress(); 
 

 
     this.customerForm.valueChanges 
 
      .subscribe(data => this.onValueChanged(data)); 
 

 
     this.onValueChanged(); // (re)set validation messages now 
 
    } 
 

 
    initAddress() { 
 
     return this._fb.group({ 
 
      'street': ['', Validators.required], 
 
      'postcode': [''] 
 
     }); 
 
    } 
 

 
    addAddress() { 
 
     const control = <FormArray>this.customerForm.controls['addresses']; 
 
     const addrCtrl = this.initAddress(); 
 

 
     control.push(addrCtrl); 
 

 
    } 
 

 
    removeAddress(i: number) { 
 
     const control = <FormArray>this.customerForm.controls['addresses']; 
 
     control.removeAt(i); 
 
    } 
 

 
    onSubmit() { 
 

 
    } 
 

 
    onValueChanged(data?: any) { 
 

 
     const form = this.customerForm; 
 

 
     for (const field in this.formErrors) { 
 
      // clear previous error message (if any) 
 

 
      const control = form.get(field); 
 

 
      if (control instanceof FormArray) { 
 

 
       const fmArray = <FormArray>control; 
 
       console.log("from Array have count : " + fmArray.controls.length); 
 
       this.formErrors[field] = []; 
 

 
       fmArray.controls.forEach(g => this.formErrors[field].push(this.addressErrors)); 
 

 
       let groupIndex = 0; 
 
       for (const groupItem of fmArray.controls) { 
 
        const group = <FormGroup>groupItem; 
 

 
        console.log("group index is here == " + groupIndex); 
 

 
        for (const ctrlField in this.addressErrors) { 
 
         const gpControl = group.controls[ctrlField]; 
 

 
         this.formErrors[field][groupIndex][ctrlField] = ''; 
 

 
         if (gpControl && gpControl.dirty && !gpControl.valid) { 
 
          const messages = this.validationMessages[ctrlField]; 
 
          for (const key in gpControl.errors) { 
 
           console.log("control error key is here ==" + key); 
 
           this.formErrors[field][groupIndex][ctrlField] += messages[key] + ' '; 
 

 
           console.log("set value on object of key is here ==" + ctrlField) 
 
           console.log(this.formErrors[field][groupIndex]); 
 
          } 
 
         } 
 

 
        } 
 
        groupIndex++; 
 
       } 
 

 
      } 
 
      else { 
 
       this.formErrors[field] = ''; 
 
       if (control && control.dirty && !control.valid) { 
 
        const messages = this.validationMessages[field]; 
 
        for (const key in control.errors) { 
 
         this.formErrors[field] += messages[key] + ' '; 
 
        } 
 
       } 
 
      } 
 

 
     } 
 
    } 
 

 
    formErrors: any = { 
 
     'name': '', 
 
     'addresses': [] 
 
    }; 
 

 
    addressErrors: any = { 
 
     'street': '' 
 
    } 
 

 
    validationMessages: any = { 
 
     'name': { 
 
      'required': 'Name is required.', 
 
      'minlength': 'Name must be at least 4 characters long.' 
 
     }, 
 
     'street': { 
 
      'required': 'Street is required.', 
 
     } 
 
    }; 
 
}
<h1> 
 
    Customer Dynamic Static Form Reactive</h1> 
 
<form [formGroup]="customerForm" (ngSubmit)="onSubmit()"> 
 
    <div class="form-group"> 
 
     <label for="name">Name</label> 
 

 
     <input type="text" id="name" class="form-control" formControlName="name"> 
 

 
     <div *ngIf="formErrors.name" class="alert alert-danger"> 
 
      {{ formErrors.name }} 
 
     </div> 
 
    </div> 
 

 
    <!--addresses--> 
 
    <div formArrayName="addresses"> 
 
     <div *ngFor="let address of customerForm.controls.addresses.controls; let i=index" class="panel panel-default"> 
 
      <div class="panel-heading"> 
 
       <span>Address {{i + 1}}</span> 
 
       <span class="glyphicon glyphicon-remove pull-right" *ngIf="customerForm.controls.addresses.controls.length > 1" (click)="removeAddress(i)"></span> 
 
      </div> 
 
      <div class="panel-body" [formGroupName]="i"> 
 
       <address [group]="address"></address> 
 
      </div> 
 
     </div> 
 
    </div> 
 

 
    <div class="margin-20"> 
 
     <a (click)="addAddress()" style="cursor: default"> Add another address + 
 
</a> 
 
</div> 
 

 
<div class="margin-20"> 
 
    <button type="submit" class="btn btn-primary pull-right" [disabled]="!customerForm.valid">Submit</button> 
 
</div> 
 
<div class="clearfix"></div> 
 

 

 
<div class="margin-20"> 
 
    <pre>formErrors: <br>{{formErrors | json}}</pre> 
 
    <div>myForm details:-</div> 
 
    <pre>Is myForm valid?: <br>{{customerForm.valid | json}}</pre> 
 
    <pre>form value: <br>{{customerForm.value | json}}</pre> 
 
</div> 
 
</form>

HTML和TS文件

+0

我說你正在因爲錯誤是從第二場傳播到組。所以地址組無效。 –

+0

一個有效,兩個無效,我同意這一點。一個人的錯誤信息應該是空的,但它不是,怎麼樣? –

回答

0

您是否嘗試過調整的角度文檔中列出的onValueChanged方法?

onValueChanged(data?: any) { 
    if (!this.heroForm) { return; } 
    const form = this.heroForm.form; 

    for (const field in this.formErrors) { 
    // clear previous error message (if any) 
    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] + ' '; 
     } 
    } 
    } 
} 

formErrors = { 
    'name': '', 
    'power': '' 
}; 
+0

喜clenkl,我照你說的,但仍不能修復這個問題。你可以幫幫我嗎? –