javascript - angular ui grid 单过滤器 + cellfilter

标签 javascript angularjs angular-ui-grid ui-grid

如文档中所述,我已经使用 ui 网格实现了单个过滤器。 http://ui-grid.info/docs/#/tutorial/321_singleFilter

但我有一个 cellFilter,当我过滤时,它过滤数据,而不是使用过滤器渲染的数据。这对最终用户来说是错误的。

例如,在这个 plunker 上,我想过滤“男性”或“女性”输入。

http://plnkr.co/edit/TNJSlc0QkBI8Tu2Jejam?p=preview

var app = angular.module('app', ['ngTouch', 'ui.grid']);

app.controller('MainCtrl', ['$scope', '$http', function ($scope, $http) {
  var today = new Date();
  $scope.gridOptions = {
    enableFiltering: false,
    onRegisterApi: function(gridApi){
      $scope.gridApi = gridApi;
      $scope.gridApi.grid.registerRowsProcessor( $scope.singleFilter, 200 );
    },
    columnDefs: [
      { field: 'name' },
      { field: 'gender', cellFilter: 'mapGender' },
      { field: 'company' },
      { field: 'email' },
      { field: 'phone' },
      { field: 'age' },
      { field: 'mixedDate' }
    ]
  };

  $http.get('https://cdn.rawgit.com/angular-ui/ui-grid.info/gh-pages/data/500_complex.json')
    .success(function(data) {
      $scope.gridOptions.data = data;
      $scope.gridOptions.data[0].age = -5;

      data.forEach( function addDates( row, index ){
        row.mixedDate = new Date();
        row.mixedDate.setDate(today.getDate() + ( index % 14 ) );
        row.gender = row.gender==='male' ? '1' : '2';
      });
    });

  $scope.filter = function() {
    $scope.gridApi.grid.refresh();
  };

  $scope.singleFilter = function( renderableRows ){
    var matcher = new RegExp($scope.filterValue);
    renderableRows.forEach( function( row ) {
      var match = false;
      [ 'name', 'company', 'email', 'gender' ].forEach(function( field ){ 
        //row.entity[field] for gender col is 1 or 2 instead of male or female
        if ( row.entity[field].match(matcher) ){
          match = true;
        }
      });
      if ( !match ){
        row.visible = false;
      }
    });
    return renderableRows;
  };
}])
.filter('mapGender', function() {
  var genderHash = {
    1: 'male',
    2: 'female'
  };

  return function(input) {
    if (!input){
      return '';
    } else {
      return genderHash[input];
    }
  };
});

最佳答案

有一个名为 filterCellFiltered 的单元格选项,您可以将其应用于您的 columnDef:

{ field: 'gender', cellFilter: 'mapGender', filterCellFiltered: true },

uiGrid 将在应用“搜索”过滤器之前应用 cellFilter。不幸的是,此选项仅适用于 columnFilters。但是我们仍然可以在我们的 singleFilter 代码中使用它来检查我们是要匹配正常值还是过滤后的值。

不确定这是否是最好的方法,但这是我的解决方案:

  $scope.singleFilter = function( renderableRows ){
    var matcher = new RegExp($scope.filterValue);
    renderableRows.forEach( function( row ) {
      var match = false;
      row.grid.columns.forEach(function( column ){

        // get the filtered value, if filterCellFiltered option is set      
        var value;
        if ( column.filterCellFiltered ){
          value = row.grid.getCellDisplayValue(row, column);
        } else {
          value = row.grid.getCellValue(row, column);
        }

        if ( value.toString().match(matcher) ){
          match = true;
        }
      });

      if ( !match ){
        row.visible = false;
      }
    });
    return renderableRows;
  };

关于javascript - angular ui grid 单过滤器 + cellfilter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43845251/

相关文章:

javascript - Angular Ui-Grid 条件 CellTemplate

javascript - 使用新参数创建已创建函数的副本?

javascript - 正则表达式替换不替换(谷歌应用程序脚本)

AngularJs 不验证无效的下拉选择

javascript - Angular ui网格错误: not found: . ui-grid-header-cell .ui-grid-cell-contents

angularjs - 在 ui-grid 3.0 中标记修改后的单元格/行 $dirty

javascript - 如何输出 slider 的 RGB 值?

javascript - 如何使用数组过滤对象?

css - Angular 淡入淡出过渡不起作用

angularjs - 在文本区域中插入制表符