如何将两个过滤的ui网格合并为一个

问题描述 投票:1回答:1

我正在使用angularjs ui grid api。我创建了一个单独的html输入标记,根据用户输入将过滤器应用于所有列。我想过滤每一列,然后将结果合并到一个ui网格中

我试图遍历每一列,并将输入标记中的文本过滤器应用于所有列。然而,这会在ui网格中查找包含所有列中输入标记的文本的行。我想显示所有包含至少一个包含过滤字符串的列的行,而不是所有包含所有列中的过滤字符串的行

angular.module('main').controller('mainCtrl',function($ scope,$ filter,uiGridConstants){

    // ********************************************
    // ui-grid configuration and functionality
    // ********************************************
    $scope.atlasUserMonitorGrid = {

        enableSorting: true,
        enableFiltering: true,
        enableGridMenu: true,
        enableColumnMenus: false,

        // pagination settings
        paginationPageSizes: [1, 2, 5, 10],
        paginationPageSize: 5,

        // Dummy test data
        data: [
            {counter: 1, username: 'bob27', last_view: '27/12/2018', total_views: 48, group: 'group 1', data_view: 32, records: 3, crosstabs: 8, reports: 5, explorer: 3, bookmarks: 2},
            {counter: 2, username: 'sarah01', last_view: '04/01/2019', total_views: 8, group: 'group 2', data_view: 2, records: 2, crosstabs: 7, reports: 4, explorer: 2, bookmarks: 12},
            {counter: 3, username: 'jono0501', last_view: '09/01/2019', total_views: 33, group: 'group 1', data_view: 12, records: 7, crosstabs: 4, reports: 18, explorer: 78, bookmarks: 44},
            {counter: 4, username: 'peterh', last_view: '21/01/2019', total_views: 33, group: 'group 3', data_view: 111, records: 12, crosstabs: 6, reports: 55, explorer: 9, bookmarks: 5},
            {counter: 5, username: 'joe201', last_view: '11/02/2019', total_views: 34, group: 'group 1', data_view: 3, records: 17, crosstabs: 24, reports: 128, explorer: 178, bookmarks: 144},
            {counter: 6, username: 'amy_mcN', last_view: '25/01/2019', total_views: 65, group: 'group 2', data_view: 212, records: 27, crosstabs: 14, reports: 718, explorer: 278, bookmarks: 244},
            {counter: 7, username: 'ke', last_view: '15/02/2019', total_views: 1156, group: 'group 3', data_view: 1124, records: 47, crosstabs: 64, reports: 17, explorer: 378, bookmarks: 344},
        ],

        columnDefs: [
            {
                field: 'counter',
                displayName: '',
                name: 'Counter',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: false,
                enableFiltering: false,
                width: 45
            },
            {
                field: 'username',
                displayName: 'Username',
                name: 'Username',
                type: 'string',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    term: ''
                }
            },
            {
                field: 'last_view',
                displayName: 'Last View',
                name: 'Last View',
                type: 'date',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }

            },
            {
                field: 'total_views',
                displayName: 'Total Views',
                name: 'Total Views',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }
            },
            {
                field: 'group',
                displayName: 'Group',
                name: 'Group',
                type: 'string',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    term: ''
                }
            },
            {
                field: 'data_view',
                displayName: 'Data View',
                name: 'Data View',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }
            },
            {
                field: 'records',
                displayName: 'Records',
                name: 'Records',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }
            },
            {
                field: 'crosstabs',
                displayName: 'Crosstabs',
                name: 'Crosstabs',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }
            },
            {
                field: 'reports',
                displayName: 'Reports',
                name: 'Reports',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }
            },
            {
                field: 'explorer',
                displayName: 'Explorer',
                name: 'Explorer',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }
            },
            {
                field: 'bookmarks',
                displayName: 'bookmarks',
                name: 'bookmarks',
                type: 'number',
                sortDirectionCycle: [uiGridConstants.ASC, uiGridConstants.DESC],
                enableSorting: true,
                enableFiltering: true,
                filter: {
                    condition: uiGridConstants.filter.EXACT
                }
            }
        ],
    };

    // ********************************************
    // Filtering configuration and functionality
    // ********************************************
    $scope.filterGrid = function(filterValue) {

        // Looping through all columns that have filtering enabled
        // and are of type string
        for (var i = 0; i < $scope.atlasUserMonitorGrid.columnDefs.length; i++) {

            if ($scope.atlasUserMonitorGrid.columnDefs[i].enableFiltering == true
                && $scope.atlasUserMonitorGrid.columnDefs[i].type === "string") {

                // setting term variable in the columnDefs filter object to equal
                // the filterValue passed into the function
                $scope.atlasUserMonitorGrid.columnDefs[i].filter.term = filterValue;
            }
        }
    }

FIRTHERBY:BOIGRI d

名称组

bob group1

约翰组2

amy bobo_group

预期成绩:

result

名称组

bob group1

amy bobo_group

actual results:

名称组

*空*

这是因为过滤正在查找名称和组列中包含字符串“bo”的行。如果名称或组列中包含字符串“bo”,我希望它过滤ui网格。

javascript angularjs filter filtering ui-grid
1个回答
0
投票

由于Remko的链接,我解决了我的问题。

我已经附上了以下链接,以帮助我实现单个过滤器的文档

http://ui-grid.info/docs/#!/tutorial/Tutorial:%20321%20Single%20filter

© www.soinside.com 2019 - 2024. All rights reserved.