获取 ngFor 项目的索引并更新值

sky*_*dev 0 ngfor angular

我正在尝试更新 Angular 模板中输入字段的文本值。模板数据值在 NgFor 循环中生成,该循环从 Web 服务获取值。这是我的模板。

<ul *ngFor="let item of vals?.bu">
  <li>
    <table>
          <tr>
            <td><button type="button" class="btn btn-info">{{item?.id}}</button></td>
            <td><input type="text" [(ngModel)]="item.bcluster"></td>
            <td><input type="text" [(ngModel)]="item.bsector"></td>
            <td><button type="button" id={{item?.id}} (click)="update($event)">Update</button></td>
          </tr>
          <tr>
            <td></td>
            <td><input type="text" [(ngModel)]="item.bgroup"></td>
            <td><input type="text" [(ngModel)]="item.bunit"></td>
            <td><button type="button" id={{item?.id}} (click)="delete($event)">Delete</button></td>
          </tr>
      </table>

  </li>
</ul>
Run Code Online (Sandbox Code Playgroud)

我现在需要从模板中获取字段的值,即“bcluster、bsector、bgroup、bunit”到我的 TS 文件中,以便调用更新 API 调用(通过更新按钮上的点击事件),但是当我尝试获得未定义的值,因为我没有获得确切的行索引。我不知道如何做到这一点。

这是我的 TS 文件(只是想把值调出来)

  update(event) {
    console.log(this.bcluster);
  }
Run Code Online (Sandbox Code Playgroud)

jit*_*der 5

您应该从模板中传递 item 和 index 之类的东西

<ul *ngFor="let item of vals?.bu; let i = index;">
  <li>
    <table>
          <tr>
            <td><button type="button" class="btn btn-info">{{item?.id}}</button></td>
            <td><input type="text" [(ngModel)]="item.bcluster"></td>
            <td><input type="text" [(ngModel)]="item.bsector"></td>
            <td><button type="button" id={{item?.id}} (click)="update(item,i)">Update</button></td>
          </tr>
      </table>

  </li>
</ul>
Run Code Online (Sandbox Code Playgroud)

比在 ts

update(item,idx) {
    //here idx will give you the index
    console.log(item.bcluster);
  }
Run Code Online (Sandbox Code Playgroud)