如何在按钮表中添加按钮编辑/删除

时间:2019-07-16 10:46:41

标签: angular angular-material

我想在我的“动作”列中有两个垫子按钮 一编辑和一删除。

有我的桌子

 <table mat-table
       [dataSource]="dataSource" multiTemplateDataRows
       class="mat-elevation-z8">
  <ng-container matColumnDef="{{column}}" *ngFor="let column of columnsToDisplay">
    <th mat-header-cell *matHeaderCellDef> {{column}} </th>
    <td mat-cell *matCellDef="let aliasesData"> {{aliasesData[column]}} </td>
  </ng-container>

有columnToDisplay

columnsToDisplay = ['id', 'domain_id', 'source', 'action'];

我想在每行按钮的“操作”列下进行编辑和删除。

2 个答案:

答案 0 :(得分:1)

<table mat-table [dataSource]="tableData" class="mat-elevation-z8">
        <ng-container *ngFor="let col of tab.table_columns" [matColumnDef]="col.name">
            <ng-container *ngIf="col.name !== 'action' ">
                <th mat-header-cell *matHeaderCellDef> {{ col.title }} </th>
                <td mat-cell *matCellDef="let element"> {{ element[col.name] }}</td>
            </ng-container>
            <ng-container *ngIf="col.name === 'action' ">
                <th mat-header-cell *matHeaderCellDef> {{ col.title }} </th>
                <td mat-cell *matCellDef="let element"><button>View Details</button></td>
            </ng-container>
        </ng-container>
        <tr mat-header-row *matHeaderRowDef="displayedColumn"></tr>
        <tr mat-row *matRowDef="let row; columns: displayedColumn"></tr>
    </table>

答案 1 :(得分:0)

我有解决方案,但这并不完美。

<table mat-table [dataSource]="dataSource"
    multiTemplateDataRows class="mat-elevation-z8">
    <ng-container matColumnDef="{{column}}"
        *ngFor="let column of columnsToDisplay">
    <th mat-header-cell *matHeaderCellDef>
      {{column !== 'action' ? column : ''}}
    </th>
  <ng-container *ngIf="column !== 'action'">
    <td mat-cell *matCellDef="let aliasesData">
       <span>{{aliasesData[column]}}</span>
    </td>
    </ng-container>
  <ng-container *ngIf="column === 'action'">
    <td mat-cell *matCellDef="let aliasesData">
       <span>
         <button>Edit</button>
         <button>Delete</button>
       </span>
    </td>
  </ng-container>
  </ng-container>
  <tr mat-header-row *matHeaderRowDef="columnsToDisplay"></tr>
  <tr mat-row *matRowDef="let row; columns: columnsToDisplay;"></tr>
</table>

您可以具有 ngIf 绑定来检查列 action 并仅显示按钮。


或具有2列显示数组

columnsToDisplay = ['id', 'domain_id', 'source'];

columnsForConfig = ['id', 'domain_id', 'source', 'action'];

并在底部使用一个进行渲染,另一个在底部进行配置,并在 ngFor 绑定之后将操作作为单独的部分进行操作。

<table mat-table [dataSource]="dataSource" multiTemplateDataRows class="mat-elevation-z8">
    <ng-container matColumnDef="{{column}}" *ngFor="let column of columnsToDisplay">
        <th mat-header-cell *matHeaderCellDef>
            {{column}}
        </th>
        <td mat-cell *matCellDef="let aliasesData">
            <span>{{aliasesData[column]}}</span>
        </td>
    </ng-container>
    <ng-container matColumnDef="action">
        <th mat-header-cell *matHeaderCellDef>
            actions
        </th>
        <td mat-cell *matCellDef="let aliasesData">
            <button>Edit</button>
            <button>Delete</button>
        </td>
    </ng-container>
    <tr mat-header-row *matHeaderRowDef="columnsForConfig"></tr>
    <tr mat-row *matRowDef="let row; columns: columnsForConfig;"></tr>
</table>