Data Grid - Filtering
Easily filter your rows based on one or several criteria.
The filters can be modified through the Data Grid interface in several ways:
- By opening the column menu and clicking the Filter menu item.
- By clicking the Filters button in the Data Grid toolbar (if enabled).
Each column type has its own filter operators. The demo below lets you explore all the operators for each built-in column type.
See the dedicated section to learn how to create your own custom filter operator.
Single and multi-filters
Pass filters to the Data Grid
Structure of the model
The full typing details can be found on the GridFilterModel API page.
The filter model is composed of a list of items and a logicOperator:
The items
A filter item represents a filtering rule and is composed of several elements:
- filterItem.field: the field on which the rule applies.
- filterItem.value: the value to look for.
- filterItem.operator: name of the operator method to use (for example contains), matches the- valuekey of the operator object.
- filterItem.id(): required when multiple filter items are used.
The logicOperator 
The logicOperator tells the Data Grid if a row should satisfy all (AND) filter items or at least one (OR) in order to be considered valid.
// Example 1: get rows with rating > 4 OR isAdmin = true
const filterModel: GridFilterModel = {
  items: [
    { id: 1, field: 'rating', operator: '>', value: '4' },
    { id: 2, field: 'isAdmin', operator: 'is', value: 'true' },
  ],
  logicOperator: GridLogicOperator.Or,
};
// Example 2: get rows with rating > 4 AND isAdmin = true
const filterModel: GridFilterModel = {
  items: [
    { id: 1, field: 'rating', operator: '>', value: '4' },
    { id: 2, field: 'isAdmin', operator: 'is', value: 'true' },
  ],
  logicOperator: GridLogicOperator.And,
};
If no logicOperator is provided, the Data Grid will use GridLogicOperator.Or by default.
Initialize the filters
To initialize the filters without controlling them, provide the model to the initialState prop.
<DataGrid
  initialState={{
    filter: {
      filterModel: {
        items: [{ field: 'rating', operator: '>', value: '2.5' }],
      },
    },
  }}
/>
Controlled filters
Use the filterModel prop to control the filter applied on the rows.
You can use the onFilterModelChange prop to listen to changes to the filters and update the prop accordingly.
<DataGrid
  filterModel={{
    items: [{ field: 'rating', operator: '>', value: '2.5' }],
  }}
/>
Disable the filters
For all columns
Filters are enabled by default, but you can easily disable this feature by setting the disableColumnFilter prop.
<DataGrid disableColumnFilter />
For some columns
To disable the filter of a single column, set the filterable property in GridColDef to false.
In the example below, the rating column cannot be filtered.
<DataGrid columns={[...columns, { field: 'rating', filterable: false }]} />
Filter non-filterable columns programmatically
You can initialize the filterModel, set the filterModel prop, or use the API method apiRef.current.setFilterModel to set the filters for non-filterable columns. These filters will be applied but will be read-only on the UI and the user won't be able to change them.
const columns = [
  { field: 'name', filterable: false },
  ...otherColumns,
]
<DataGrid
  filterModel={{
    items: [{ field: 'name', operator: 'contains', value: 'a' }],
  }}
  columns={columns}
/>
Ignore diacritics (accents)
When filtering, diacritics—accented letters such as é or à—are considered distinct from their standard counterparts (e and a). This can lead to a poor experience when users expect them to be treated as equivalent.
If your dataset includes diacritics that need to be ignored, you can pass the ignoreDiacritics prop to the Data Grid:
<DataGrid ignoreDiacritics />
apiRef
The Data Grid exposes a set of methods via the apiRef object that are used internally in the implementation of the filtering feature.
The reference below describes the relevant functions.
See API object for more details.
Signature:
deleteFilterItem: (item: GridFilterItem) => voidSignature:
getFilterState: (filterModel: GridFilterModel) => GridStateCommunity['filter']Signature:
hideFilterPanel: () => voidSignature:
ignoreDiacritics: DataGridProcessedProps['ignoreDiacritics']Signature:
setFilterLogicOperator: (operator: GridLogicOperator) => voidSignature:
setFilterModel: (model: GridFilterModel, reason?: GridControlledStateReasonLookup['filter']) => voidSignature:
setQuickFilterValues: (values: any[]) => voidSignature:
showFilterPanel: (targetColumnField?: string, panelId?: string, labelId?: string) => voidSignature:
upsertFilterItem: (item: GridFilterItem) => voidSignature:
upsertFilterItems: (items: GridFilterItem[]) => voidSignature:
gridExpandedRowCountSelector: (apiRef: GridApiRef) => numberExample
const expandedRowCount = gridExpandedRowCountSelector(apiRef);Signature:
gridExpandedSortedRowEntriesSelector: (apiRef: GridApiRef) => GridRowEntry<GridValidRowModel>[]Example
const expandedSortedRowEntries = gridExpandedSortedRowEntriesSelector(apiRef);Signature:
gridExpandedSortedRowIdsSelector: (apiRef: GridApiRef) => GridRowId[]Example
const expandedSortedRowIds = gridExpandedSortedRowIdsSelector(apiRef);Signature:
gridFilterModelSelector: (apiRef: GridApiRef) => GridFilterModelExample
const filterModel = gridFilterModelSelector(apiRef);Signature:
gridFilteredDescendantRowCountSelector: (apiRef: GridApiRef) => numberExample
const filteredDescendantRowCount = gridFilteredDescendantRowCountSelector(apiRef);Signature:
gridFilteredRowCountSelector: (apiRef: GridApiRef) => numberExample
const filteredRowCount = gridFilteredRowCountSelector(apiRef);Signature:
gridFilteredSortedRowEntriesSelector: (apiRef: GridApiRef) => GridRowEntry<GridValidRowModel>[]Example
const filteredSortedRowEntries = gridFilteredSortedRowEntriesSelector(apiRef);Signature:
gridFilteredSortedRowIdsSelector: (apiRef: GridApiRef) => GridRowId[]Example
const filteredSortedRowIds = gridFilteredSortedRowIdsSelector(apiRef);Signature:
gridFilteredSortedTopLevelRowEntriesSelector: (apiRef: GridApiRef) => GridRowEntry<GridValidRowModel>[]Example
const filteredSortedTopLevelRowEntries = gridFilteredSortedTopLevelRowEntriesSelector(apiRef);Signature:
gridFilteredTopLevelRowCountSelector: (apiRef: GridApiRef) => numberExample
const filteredTopLevelRowCount = gridFilteredTopLevelRowCountSelector(apiRef);Signature:
gridQuickFilterValuesSelector: (apiRef: GridApiRef) => any[] | undefinedExample
const quickFilterValues = gridQuickFilterValuesSelector(apiRef);More information about the selectors and how to use them on the dedicated page