Data Grid - Quick Filter component
Provide users with an expandable search field to filter data in the Data Grid.
The quick filter feature is enabled by default when showToolbar is passed to the <DataGrid /> component.
You can use the Quick Filter and Toolbar components when you need to customize the quick filter, or when implementing a custom toolbar.
Basic usage
The demo below shows how to compose the various Quick Filter parts to look and behave like the built-in toolbar quick filter.
Anatomy
import {
  QuickFilter,
  QuickFilterControl,
  QuickFilterClear,
  QuickFilterTrigger,
} from '@mui/x-data-grid';
<QuickFilter>
  <QuickFilterTrigger />
  <QuickFilterControl />
  <QuickFilterClear />
</QuickFilter>;
Quick Filter
<QuickFilter /> is the top level component that provides context to child components.
It renders a <div /> element.
Quick Filter Control
<QuickFilterControl /> takes user input and filters row data.
It renders the baseTextField slot.
Quick Filter Clear
<QuickFilterClear /> is a button that resets the filter value.
It renders the baseIconButton slot.
Quick Filter Trigger
<QuickFilterTrigger /> is a button that expands and collapses the quick filter.
It renders the baseButton slot.
Custom elements
Use the render prop to replace default elements.
See Components usage—Customization for more details, and Toolbar—Custom elements demo for an example of a custom Quick Filter.
Recipes
Below are some ways the Quick Filter component can be used.
Default expanded state
The quick filter is uncontrolled by default and can be toggled via the trigger. The defaultExpanded prop can be used to set the default expanded state.
Expand quick filter via keyboard
The demo below shows how to control the quick filter state using the expanded and onExpandedChange props to support expanding the quick filter via keyboard. You can try it by clicking on any cell to ensure the data grid has focus, and then pressing Cmd (or Ctrl on Windows)+P.
Persistent quick filter
The demo below shows how to display a persistent quick filter by passing the expanded prop to the <QuickFilter /> component.
Accessibility
ARIA
- You must render a <label />with aforattribute set to theidof<QuickFilterControl />, or apply anaria-labelattribute to the<QuickFilterControl />.
- You must apply a text label or an aria-labelattribute to the<QuickFilterClear />and<QuickFilterTrigger />.
Keyboard
| Keys | Description | 
|---|---|
| Escape | Clears quick filter value. If already empty, collapses the filter. | 
API
See the documentation below for a complete reference to all of the props and classes available to the components mentioned here.