javascript - Angular 4嵌套formArray/formGroup将数据库查询中的值放回表单中

标签 javascript angular path nested-forms formarray

我有一个嵌套的 for 数组。我想编辑表单中的值,因此我执行了数据库查询来获取要编辑的值,但我无法将它们(personRows3 值)放在正确的输入字段中。 personRows3 是一个嵌套表单数组,它具有一个或多个表单组(personI3、personR3),请参阅下面的 seg_inf
我收到错误:
错误:找不到路径为“segmentRows3 -> 0”的控件
这是 .html 代码

<form *ngIf="row" [formGroup]="myEditSummaryForm" (ngSubmit)="saveASummary(myEditSummaryForm.value)">
<div class="container">
<div formArrayName="segmentRows3">
  <div *ngFor=" let seg of seg_inf; let i= index " > 
    <div  class="form-group" [formGroupName]="i" >    <---error line----
      <label for="segmentId3">Segment ID {{i+1}}  
        <input type="text" formControlName="segmentId3" id="segmentId3" class="form-control" value="{{i+1}}" >          
      </label>   
      <label><span *ngIf="seg_inf.length > 1" (click)="deleteSegment(i)" class="btn btn-danger">Remove segment</span></label>
      <label for="segmentTime3">Segment time : 
        <timepicker formControlName="segmentTime3" (ngModel)="segmentTime3" [showMeridian]="isMeridian" [showSpinners]="showSpinners"> </timepicker> </label> 
      <button type="button" (click)="addPerson(i)" class="btn btn-info">Add a person</button>
       {{seg.personRows3 |json}}<br>
      <div formArrayName="personRows3">
        <div *ngFor=" let per of seg.personRows3; let j=index " > 
          <div class="form-group" [formGroupName]="j">   #{{j+1}}   
            <label for="personR3">Segment type 
              <input formControlName="personR3" [typeahead]="personRole" type="text" id="personR3" class="form-control">
            </label>
            <label for="personI3">Person name   
              <input formControlName="personI3" [typeahead]="states" type="text" id="personI3" class="form-control">
            </label>
            <label><span *ngIf="seg_inf.length > 1" (click)="deletePerson(i,j)" class="btn btn-warning">Remove</span></label>
          </div>
        </div>
      </div>
      <label for="topic">Topic</label>
        <textarea formControlName="topic" id="topic" class="form-control" (ngModelChange)="onChange($event)"></textarea>  
    </div>            
  </div>
</div>
<button type="button" (click)="addSegment(i)" class="btn btn-primary">Add a segment</button>  
</div>
 <div>
  <button class="btn btn-success form-control" 
(click)="saveASummary(myEditSummaryForm.value)"> Save update(s)</button>
 </div>             
</form> 

这是.ts代码

for (var i = 0, len = this.seg_inf.length; i < len; i++) {
  let segmentRows3 = <FormArray>this.myEditSummaryForm.get('segmentRows3');
  segmentRows3.push(
    this.fb.group({
    segmentTime3: this.seg_inf[i].segmentTime3, 
    segmentId3: i+1, 
    topic: this.seg_inf[i].topic,    
    PersonRows3: this.getPerson(this.seg_inf, i),       //function call
      })
    );
  }    


 getPerson(s_i: any[], index: number) {
let s_i_prl = s_i[index].personRows3.length;
let s_i_pr = s_i[index].personRows3;
// get all people for that segment
for (var j = 0, lenj=s_i_prl; j < lenj; j++) {
  let personRows3 = <FormArray>this.myEditSummaryForm.get(`segmentRows3.${index}.personRows3`)
  this.fb.array([
    this.fb.group({
        personR3: s_i_pr[j].personR3,
        personI3: s_i_pr[j].personI3, 
        })
    ])
  }
}   


this.seg_inf = [{"segmentTime3":"2018-05-23T14:20:00.051Z","segmentId3":"","topic":"topic1",   
"personRows3":[{"personR3":"HS - host","personI3":"California"},{"personR3":"GS - guest","personI3":"Alaska"}]},   
 {"segmentTime3":"2018-05-23T14:30:00.533Z","segmentId3":"","topic":"topic2",   
 "personRows3":[{"personR3":"HS - host","personI3":"Arizona"}]}]   

一切正常,直到我尝试填写 personRows3 的输入字段!
您可以在添加人员按钮之后看到:{{seg.personRows3 |json}}

enter image description here

这是一个nonworking code 。我缺少什么?

@yurzui 回答后:
enter image description here

最佳答案

它不应该像 getPerson 方法那样复杂,实际上返回任何内容。

您可以使用以下代码:

personRows3: this.getPerson(this.seg_inf[i].personRows3);
...

getPerson(personRows: any[]) {
  return this.fb.array(
    personRows.map(p => this.fb.group({
      personR3: p.personR3,
      personI3: p.personI3,
    })
  ))
}

这里我返回 FormGroupsFormArray,它基于您的 personRows3 数组。

您也可以在Ng-run Example中查看。

关于javascript - Angular 4嵌套formArray/formGroup将数据库查询中的值放回表单中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50499947/

相关文章:

Angular Material : Change background color of a dialog window

javascript - 如何使用 Angular 进行 HTTP 基本身份验证

Unix:获取导出路径到 "Stick"

c# - 解析Excel的路径

javascript - 如何从单个数组创建多维数组或对象?

javascript - getBoundingClientRect 根据滚动位置动态变化?

javascript - 我如何集中所有值为空的类字段?

unit-testing - Angular2 - 单元测试表单提交

javascript - 如何使用复选框打印选定的值并打印它们而不得到未定义的值?

dll - 更改dll文件头中的pdb文件路径