我有一个应用程序有一个图形组件,我的想法是,当使用点击图表时,正确的过滤将发生在另一个组件上,这是一个primeng数据表
为此我创建了一个事件,我可以在表组件上捕获事件
然后我尝试了两种正确过滤表的方法
1.使用ngModel,根据事件设置值 - 不工作
<p-column field="result" [filter]="true" [style]="{'overflow':'visible'}" filterMatchMode="equals">
<ng-template let-col let-compliance="rowData" let-ri="rowIndex" pTemplate="body">
<span [ngClass]="{green: compliance.result=='SUCCESS', red: compliance.result=='FAILURE',
orange: compliance.result=='EXCLUDED', grey: compliance.result=='UNCHECKED'}">{{compliance.result}}</span>
</ng-template>
<ng-template pTemplate="filter" let-col>
<p-dropdown [options]="stationResults" [style]="{'width':'100%'}" appendTo="body"
(onChange)="dt.filter($event.value,col.field,col.filterMatchMode)" styleClass="ui-column-filter" [(ngModel)]="selectedResult"></p-dropdown>
</ng-template>
</p-column>
表未被过滤
后来我尝试了第二种方法
2.add过滤属性到数据表
this.stationService.upDownGraphEvent.subscribe(upDownEvent => {
this.dt.filter(upDownEvent, 'result', 'equals');
this.selectedResult = upDownEvent;
});
在这种情况下没有任何事情发生
我需要在dt上调用一个函数来强制它重新检查它的过滤器吗?
更新******
我尝试过以下代码,但没有成功
this.dt.filter(upDownEvent, 'result', 'equals');
this.dt._filter();
this.dt.updateDataToRender(this.dt.filteredValue);
答案 0 :(得分:0)
您可以使用globalFilter属性绑定,如下所示
<input #filterText type="text" placeholder="Search text...">
<p-dataTable [value]="compliance" [globalFilter]="filterText">
答案 1 :(得分:0)
this.alertService.alertSwitchGraphEvent.subscribe(switchNameEvent => {
if(this.dt.dataToRender){
this.dt.filter(switchNameEvent, 'switchName', 'equals');
}
});
我已经在我订阅它的数据表组件上创建了一个发出的外部事件 然后我调用dt.filter