Angular2 primeNG数据表来自外部事件的过滤数据

时间:2017-04-28 03:39:17

标签: angular primeng

我有一个应用程序有一个图形组件,我的想法是,当使用点击图表时,正确的过滤将发生在另一个组件上,这是一个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);

2 个答案:

答案 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