css - Angular:如何使用查询参数过滤数据表

标签 css angular typescript angular-material material-design

我想使用从另一个组件中的用户输入获得的查询参数来过滤我的表。

我能够获取用户通过输入发送的数据并将其打印到 console.log。但我不知道如何使用它来过滤表格。

我已经构建了一个过滤器,但由于某些原因我无法调用它。

这是我的过滤器:

import { Pipe, PipeTransform } from "@angular/core";
import { Container } from "./Entites/Container";

@Pipe({
  name: 'textFilter'
})
export class textFilter implements PipeTransform {

  transform(
    containers : Container[],
    storageSearch?: any,
    clientSearch?: string,
  ): Container[] {

    if (!containers) return [];
    if (!storageSearch) return containers;
    storageSearch = storageSearch.toLocaleLowerCase();
    containers = [...containers.filter(user => user.TAOR_QTSR_EBRI.toLocaleLowerCase() ===  storageSearch)];

    if (!clientSearch) return containers;
    clientSearch = clientSearch.toLocaleLowerCase();
    containers = [...containers.filter(user => user.LQOCH_SHM_LEOZI_QTSR.toLocaleLowerCase() ===  clientSearch)];

  // if (!roleSearch) return users;
  //roleSearch = roleSearch.toLocaleLowerCase();
  //users = [...users.filter(user => user.role.toLocaleLowerCase() ===  roleSearch)];

    return containers;
  }
}

这是我的组件 ngOnInit 我还有一些其他过滤器,例如复选框过滤器:

  ngOnInit() {
    this.marinService.getAllContainers().subscribe((result) => {
     //Data
      this.dataSource = new MatTableDataSource(result);
      //Paginator
      this.dataSource.paginator = this.paginator;
      //AutoFilter Form 1st page
      this.clientType = this.route.snapshot.queryParamMap.get('clientType');
      this.storageType= this.route.snapshot.queryParamMap.get('storageTypes');
      console.log('The Client name is : '+this.clientType+'  '+'The storage Facility is : '+this.storageType);
      //CheckBox Filter
      this.dataSource.filterPredicate = (data: Container, filter: any) => {
        return filter.split(',').every((item: any) => data.SOG_MCOLH.indexOf(item) !== -1);
      };

      this.filterCheckboxes.subscribe((newFilterValue: any[]) => {
        this.dataSource.filter = newFilterValue.join(',');
      });

    });
  }

我想要完成的是能够使用查询参数过滤表。

最佳答案

我们可以将您收到的数据作为输入(在父组件中)传递给子组件内的 Material 表过滤函数 applyFilter...

相关父TS:

import { Component } from '@angular/core';
@Component({
  selector: 'app-root',
  styles: [`.parent{background:lightgreen; padding:2%;}`],
  template: `
  Enter string for filtering: <input type='text' [(ngModel)]='inputStr' />
  <!-- {{inputStr}} -->
  <table-filtering-example [inputStr]='inputStr'>loading</table-filtering-example>
  `,
})
export class AppComponent {
  inputStr: string = '';
  constructor() { }
}

相关子TS:

export class TableFilteringExample implements OnInit, OnChanges {
  displayedColumns: string[] = ['position', 'name', 'weight', 'symbol'];
  dataSource = new MatTableDataSource(ELEMENT_DATA);
  @Input() inputStr:string;

  constructor(){}

  ngOnInit(){}

  ngOnChanges(){
     /* just call the applyFilter button with the data which is passed to your component from it's parent */console.log("(ngOnChanges)this.inputStr:", this.inputStr); 
     this.applyFilter(this.inputStr);
     }

  applyFilter(filterValue: string) {
    this.dataSource.filter = filterValue.trim().toLowerCase();
  }
}

完成working stackblitz here

关于css - Angular:如何使用查询参数过滤数据表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56848421/

相关文章:

html - 下拉导航列表

javascript - (SystemJS) 意外标记 < ( ASP.net + Angular 4)

Angular 5 - 未捕获的 ReferenceError : req is not defined

javascript - TypeScript 空对象文字类型注解

typescript - 使用动态导入时 Jest 与自定义错误类型不匹配

javascript - typescript 和正则表达式

javascript - 使用 Angular JS 的自定义分页 - 需要在第一页显示 div 元素,该元素应该在第二页上重复单击下一步

javascript - 如何使用 JavaScript 禁用主菜单?

jquery - 使用 JQuery 时 TinyMCE 不适合页面

angular - Angular2 Http 请求如何以二进制形式返回正文?