在PrimeNG表上应用重置方法会重置图标,但不会重置数据。
HTML
<button (click)="onReset(dt)">Reset Table</button>
TS
onReset = (table) => {
table.reset();
}
答案 0 :(得分:0)
这是我的模板代码,它的工作原理很简单:
<p-table #tt [columns]="cols" [value]="rowData" sortField="Id" [paginator]="true" [rows]="10" [lazy]="true"
(onLazyLoad)="loadListLazy($event)" [totalRecords]="totalRecords" [responsive]="true">
<ng-template pTemplate="header" let-columns>
<tr>
<th *ngFor="let col of columns" class="ui-table-thead-filter" [ngSwitch]="col.field">
<input *ngSwitchCase="'Id'" class="form-control" pInputText type="text" style="width: 100%" (input)="tt.filter($event.target.value, col.field, col.filterMatchMode)">
<input *ngSwitchCase="'Name'" class="form-control" pInputText type="text" style="width: 100%" (input)="tt.filter($event.target.value, col.field, col.filterMatchMode)">
<p-button class="btn btn-cancel" *ngSwitchCase="'Actions'" label="Clear filters" (click)="tt.reset()"></p-button>
</th>
</tr>
<tr>
<th *ngFor="let col of columns" [pSortableColumn]="col.field"
[pSortableColumnDisabled]="col.field === 'Actions'">
{{col.header}}
<p-sortIcon *ngIf="col.field !== 'Actions'" [field]="col.field"></p-sortIcon>
</th>
</tr>
</ng-template>
<ng-template pTemplate="body" let-rowData let-columns="columns">
<tr>
<td>{{rowData["Id"]}}</td>
<td>{{rowData["Name"]}}</td>
<td class="text-center">
<input pButton (click)="onEdit(rowData['Id'])" value="Edit" class="btn btn-sm btn-edit" />
</td>
</tr>
</ng-template>
您不需要在打字稿中做任何事情。 只有tt.reset()
但是我还有一个问题要问大家。 tt.reset()函数未清除过滤器输入。是否有任何简单的方法,或者我需要创建如下函数:clearAllFilters(){}并手动清除搜索栏中的所有输入?