1

我有一个带有复选框选择的 TurboTable 定义,如下所示:

<p-table [columns]="cols" [value]="dataJSONArray" [paginator]="true" [rows]="10" [scrollable]="true"
  [(selection)]="dtSelectedRows" dataKey="OrderId">
  <ng-template pTemplate="colgroup" let-columns>
    <colgroup>
      <col style="width: 3em">
      <col *ngFor="let col of columns" [ngStyle]="{'width': col.widthPx + 'px'}">
    </colgroup>
  </ng-template>
  <ng-template pTemplate="header">
    <tr>
      <th>
        <p-tableHeaderCheckbox></p-tableHeaderCheckbox>
      </th>
      <th *ngFor="let col of cols">{{col.header}}</th>
    </tr>
  </ng-template>
  <ng-template pTemplate="body" let-rowData let-col>
    <tr [pSelectableRow]="rowData">
      <td>
        <p-tableCheckbox [value]="rowData"></p-tableCheckbox>
      </td>
...

如果我更改 dtSelectedRows 数组(选择),则不会发生任何事情(dtSelectedRows 数组更改,但选中的列不会更改-保持选中-):

this.dtSelectedRows.splice(indx, 1);

但是,如果我将一个数组分配给 dtSelectedRows 数组,则更改会生效:

let dummySelectedRow = Object.assign([], this.dtSelectedRows);
dummySelectedRow.splice(indx, 1);
this.dtSelectedRows = dummySelectedRow;
4

1 回答 1

1

single在这种情况下,您需要将选择模式dtSelectedRows属性设置为对选定值数组的对象实例的引用。

<p-tableHeaderCheckbox></p-tableHeaderCheckbox>将选择模式设置为multipleselection ,如果要支持单选模式,可以使用 p-tableRadioButton(单选按钮)来解决这个问题

<p-table  [columns]="cols" [value]="data" [paginator]="true" [rows]="10" [scrollable]="true"
  [(selection)]="dtSelectedRows" >
  <ng-template pTemplate="header">
    <tr>
      <th>
      </th>
      <th *ngFor="let col of cols">{{col.header}}</th>
    </tr>
  </ng-template>
  <ng-template pTemplate="body" let-rowData let-col>
    <tr [pSelectableRow]="rowData">
       <td>
        <p-tableRadioButton [value]="rowData"></p-tableRadioButton>
      </td>
      <td *ngFor="let col of cols">{{rowData[col.field]}}<td>
    </tr>
  </ng-template>
</p-table>

按方法设置选定项

  setSelectedItem(){
    this.dtSelectedRows = this.data[0];
  }

如果您想在多种模式下根据条件删除项目

  removeUnvalidItem(){
    if (this.dtSelectedRows) {
      this.dtSelectedRows = this.dtSelectedRows.filter(car => car.year > 2005) 
    }
  }

stackblitz 演示

于 2018-09-28T08:00:15.460 回答