我想在我的“动作”列中有两个垫子按钮 一编辑和一删除。
有我的桌子
<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'];
我想在每行按钮的“操作”列下进行编辑和删除。
答案 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>