Column filter
Filter data by values or by a set of conditions, using Handsontable’s intuitive user interface or flexible API.
Overview
Filtering lets you quickly find the information that you’re looking for, based on specific criteria. This makes data analysis easier and faster, especially with large data sets.
Handsontable’s built-in filtering interface resembles Excel’s, so it’s intuitive even to non-technical users. And if you want to implement your own interface, you can easily filter data programmatically, using Handsontable’s API.
You can filter data by value, or use the built-in conditions, which are different for each of the available column types.
Filtering demo
Click on one of the column menu buttons (▼) and play around with filtering by selecting values or conditions-based criteria.
After filtering, the column readjusts its width to the longest value displayed on screen. To disable this behavior, set fixed column widths.
// to import filtering as an individual module, see the 'Import the filtering module' section of this pageimport { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;// to import filtering as an individual module, see the 'Import the filtering module' section of this pageimport { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;Enable filtering
To enable the filtering interface for all columns, you need to do two things:
- Set the
filtersoption totrue. - Enable the interface by setting the
dropdownMenuoption totrue.
Enabling the filters option without the interface can be useful if you plan to create your own
custom interface for filtering by using the API.
<HotTable // enable filtering filters={true} // enable the column menu dropdownMenu={true}/>
By default, the column menu presents the filtering interface along with other default items such as Insert column left. To display only the filtering interface, pass an array of filter items in the configuration.
import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu, but display only the filter menu items dropdownMenu={['filter_by_condition', 'filter_by_value', 'filter_action_bar']} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu, but display only the filter menu items dropdownMenu={['filter_by_condition', 'filter_by_value', 'filter_action_bar']} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;Enable filtering for individual columns
You have control over which columns are filterable and for which columns the column menu is enabled. In the following demo, only the Brand column is filterable, while the other columns are not. However, the Model column still has the column menu available in case you want to have some useful items in the menu such as Clear column.
import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { // remove the column menu button from the 'Brand', 'Price', and 'Date' columns const removeColumnMenuButton = (col, TH) => { if (col > 1) { const button = TH.querySelector('.changeType');
if (!button) { return; }
button.parentElement.removeChild(button); } };
return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering for all columns filters={true} // enable the column menu for all columns // but display only the 'Filter by value' list and the 'OK' and 'Cancel' buttons dropdownMenu={{ items: { filter_by_value: { // hide the 'Filter by value' list from all columns but the first one hidden() { return this.getSelectedRangeLast().to.col > 0; }, }, filter_action_bar: { // hide the 'OK' and 'Cancel' buttons from all columns but the first one hidden() { return this.getSelectedRangeLast().to.col > 0; }, }, clear_column: { // hide the 'Clear column' menu item from the first column hidden() { return this.getSelectedRangeLast().to.col < 1; }, }, }, }} // `afterGetColHeader()` is a Handsontable hook // it's fired after Handsontable appends information about a column header to the table header afterGetColHeader={removeColumnMenuButton} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { // remove the column menu button from the 'Brand', 'Price', and 'Date' columns const removeColumnMenuButton = (col: number, TH: { querySelector: (value: string) => any }) => { if (col > 1) { const button = TH.querySelector('.changeType');
if (!button) { return; }
button.parentElement.removeChild(button); } };
return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering for all columns filters={true} // enable the column menu for all columns // but display only the 'Filter by value' list and the 'OK' and 'Cancel' buttons dropdownMenu={{ items: { filter_by_value: { // hide the 'Filter by value' list from all columns but the first one hidden() { return this.getSelectedRangeLast()!.to.col > 0; }, }, filter_action_bar: { // hide the 'OK' and 'Cancel' buttons from all columns but the first one hidden() { return this.getSelectedRangeLast()!.to.col > 0; }, }, clear_column: { // hide the 'Clear column' menu item from the first column hidden() { return this.getSelectedRangeLast()!.to.col < 1; }, }, }, }} // `afterGetColHeader()` is a Handsontable hook // it's fired after Handsontable appends information about a column header to the table header afterGetColHeader={removeColumnMenuButton} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;Enable filtering within already filtered results
To apply filters based on the search input, set searchMode to 'apply'. You can then apply the filter by either pressing the Enter key while the search input is focused or by clicking the OK button.
<HotTable // enable filtering filters={{ searchMode: 'apply' }} // enable the column menu dropdownMenu={true}/>import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering with option filters={{ searchMode: 'apply', }} dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering with option filters={{ searchMode: 'apply', }} dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;Filter different types of data
With its built-in cell types, Handsontable makes it easy to handle common data types like text, numbers, and dates by providing numerous configuration options. In addition, the filtering feature is designed to understand the underlying data and provides an adaptive interface that is tailored to each data type.
import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { model: 'Racing Socks', size: 'S', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, color: 'Black', }, { model: 'HL Mountain Shirt', size: 'XS', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, color: 'White', }, { model: 'Cycling Cap', size: 'L', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, color: 'Green', }, { model: 'Ski Jacket', size: 'M', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, color: 'Blue', }, { model: 'HL Goggles', size: 'XL', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, color: 'Black', }, ]} columns={[ { title: 'Model', // set the type of the 'Model' column type: 'text', data: 'model', }, { title: 'Price', // set the type of the 'Price' column type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Sold on', // set the type of the 'Date' column type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', // set the type of the 'Time' column type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', // set the type of the 'In stock' column type: 'checkbox', data: 'inStock', className: 'htCenter', }, { title: 'Size', // set the type of the 'Size' column type: 'dropdown', data: 'size', source: ['XS', 'S', 'M', 'L', 'XL'], className: 'htCenter', }, { title: 'Color', // set the type of the 'Size' column type: 'autocomplete', data: 'color', source: ['White', 'Black', 'Yellow', 'Blue', 'Green'], className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height={175} autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { model: 'Racing Socks', size: 'S', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, color: 'Black', }, { model: 'HL Mountain Shirt', size: 'XS', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, color: 'White', }, { model: 'Cycling Cap', size: 'L', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, color: 'Green', }, { model: 'Ski Jacket', size: 'M', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, color: 'Blue', }, { model: 'HL Goggles', size: 'XL', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, color: 'Black', }, ]} columns={[ { title: 'Model', // set the type of the 'Model' column type: 'text', // 'text' is the default type, so you can omit this line data: 'model', }, { title: 'Price', // set the type of the 'Price' column type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Sold on', // set the type of the 'Date' column type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', // set the type of the 'Time' column type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', // set the type of the 'In stock' column type: 'checkbox', data: 'inStock', className: 'htCenter', }, { title: 'Size', // set the type of the 'Size' column type: 'dropdown', data: 'size', source: ['XS', 'S', 'M', 'L', 'XL'], className: 'htCenter', }, { title: 'Color', // set the type of the 'Size' column type: 'autocomplete', data: 'color', source: ['White', 'Black', 'Yellow', 'Blue', 'Green'], className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height={175} autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;The following table contains all available filter operators for each built-in data type.
| Cell type | Available filter operators |
|---|---|
| All cell types | Default operators: None Is empty Is not empty Is equal to Is not equal to |
| text time checkbox dropdown autocomplete password | Default operators plus: Begins with Ends with Contains Does not contain |
| numeric | Default operators plus: Greater than Greater than or equal to Less than Less than or equal to Is between Is not between |
| date | Default operators plus: Before After Is between Tomorrow Today Yesterday |
Filter data on initialization
You can filter data on Handsontable’s initialization. This lets you apply pre-defined filters every time you launch your grid.
To do this, use the API provided by the Filters plugin. For instance, the demo
below demonstrates how you can start with a pre-applied filter to display only items priced less
than $200.
// you need `useRef` to call Handsontable's instance methodsimport { useRef, useEffect } from 'react';import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { const hotTableComponentRef = useRef(null);
useEffect(() => { const handsontableInstance = hotTableComponentRef.current?.hotInstance; // get the `Filters` plugin, so you can use its API const filters = handsontableInstance?.getPlugin('filters');
// filter data by the 'Price' column (column at index 2) // to display only items that are less than ('lt') $200 filters?.addCondition(2, 'lt', [200]); filters?.filter(); }, []);
return ( <HotTable ref={hotTableComponentRef} data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;// you need `useRef` to call Handsontable's instance methodsimport { useRef, useEffect } from 'react';import { HotTable, HotTableRef } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { const hotTableComponentRef = useRef<HotTableRef>(null);
useEffect(() => { const handsontableInstance = hotTableComponentRef.current?.hotInstance; // get the `Filters` plugin, so you can use its API const filters = handsontableInstance?.getPlugin('filters');
// filter data by the 'Price' column (column at index 2) // to display only items that are less than ('lt') $200 filters?.addCondition(2, 'lt', [200]); filters?.filter(); }, []);
return ( <HotTable ref={hotTableComponentRef} data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;External quick filter
Handsontable’s quick filter feature lets you search for a particular phrase in a specific column. To
accomplish this, use methods filters.addCondition() and
filters.filter().
import { useEffect, useRef, useState } from 'react';import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const columns = [ { value: '0', label: 'Brand' }, { value: '1', label: 'Model' }, { value: '2', label: 'Price' }, { value: '3', label: 'Date' }, { value: '4', label: 'Time' }, { value: '5', label: 'In stock' },];
const ExampleComponent = () => { const hotTableComponentRef = useRef(null); const dropdownRef = useRef(null); const [selectedColumn, setSelectedColumn] = useState('0'); const [open, setOpen] = useState(false);
useEffect(() => { const handleClickOutside = (e) => { if (dropdownRef.current && !dropdownRef.current.contains(e.target)) { setOpen(false); } };
document.addEventListener('click', handleClickOutside);
return () => document.removeEventListener('click', handleClickOutside); }, []);
const handleFilter = (event) => { const handsontableInstance = hotTableComponentRef.current?.hotInstance; const filtersPlugin = handsontableInstance?.getPlugin('filters');
filtersPlugin?.removeConditions(Number(selectedColumn)); filtersPlugin?.addCondition(Number(selectedColumn), 'contains', [event.target.value]); filtersPlugin?.filter(); handsontableInstance?.render(); };
const handleSelect = (col) => { setSelectedColumn(col.value); setOpen(false); };
const selectedLabel = columns.find((c) => c.value === selectedColumn)?.label || 'Brand';
return ( <> <div className="controlsQuickFilter"> <div className="filter-dropdown" ref={dropdownRef}> <span className="filter-dropdown-label">Select a column:</span> <button className="filter-dropdown-trigger" type="button" aria-haspopup="listbox" aria-expanded={open} onClick={() => setOpen(!open)} > <span className="filter-dropdown-text">{selectedLabel}</span> <svg className="filter-dropdown-chevron" aria-hidden="true" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round"><path d="M6 9l6 6l6 -6"/></svg> </button> {open && ( <ul className="filter-dropdown-menu" role="listbox"> {columns.map((col) => ( <li key={col.value} role="option" aria-selected={col.value === selectedColumn} onClick={() => handleSelect(col)} > {col.label} </li> ))} </ul> )} </div> <input id="filterField" type="text" placeholder="Filter" onKeyUp={handleFilter} /> </div> <HotTable ref={hotTableComponentRef} data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} filters={true} height="auto" className="exampleQuickFilter" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> </> );};
export default ExampleComponent;import { useEffect, useRef, useState } from 'react';import { HotTable, HotTableRef } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const columnOptions = [ { value: '0', label: 'Brand' }, { value: '1', label: 'Model' }, { value: '2', label: 'Price' }, { value: '3', label: 'Date' }, { value: '4', label: 'Time' }, { value: '5', label: 'In stock' },];
const ExampleComponent = () => { const hotTableComponentRef = useRef<HotTableRef>(null); const dropdownRef = useRef<HTMLDivElement>(null); const [selectedColumn, setSelectedColumn] = useState('0'); const [open, setOpen] = useState(false);
useEffect(() => { const handleClickOutside = (e: MouseEvent) => { if (dropdownRef.current && !dropdownRef.current.contains(e.target as Node)) { setOpen(false); } };
document.addEventListener('click', handleClickOutside);
return () => document.removeEventListener('click', handleClickOutside); }, []);
const handleFilter = (event: React.KeyboardEvent<HTMLInputElement>) => { const handsontableInstance = hotTableComponentRef.current?.hotInstance; const filtersPlugin = handsontableInstance?.getPlugin('filters');
filtersPlugin?.removeConditions(Number(selectedColumn)); filtersPlugin?.addCondition(Number(selectedColumn), 'contains', [(event.target as HTMLInputElement).value]); filtersPlugin?.filter(); handsontableInstance?.render(); };
const handleSelect = (col: { value: string; label: string }) => { setSelectedColumn(col.value); setOpen(false); };
const selectedLabel = columnOptions.find((c) => c.value === selectedColumn)?.label || 'Brand';
return ( <> <div className="controlsQuickFilter"> <div className="filter-dropdown" ref={dropdownRef}> <span className="filter-dropdown-label">Select a column:</span> <button className="filter-dropdown-trigger" type="button" aria-haspopup="listbox" aria-expanded={open} onClick={() => setOpen(!open)} > <span className="filter-dropdown-text">{selectedLabel}</span> <svg className="filter-dropdown-chevron" aria-hidden="true" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round"><path d="M6 9l6 6l6 -6"/></svg> </button> {open && ( <ul className="filter-dropdown-menu" role="listbox"> {columnOptions.map((col) => ( <li key={col.value} role="option" aria-selected={col.value === selectedColumn} onClick={() => handleSelect(col)} > {col.label} </li> ))} </ul> )} </div> <input id="filterField" type="text" placeholder="Filter" onKeyUp={handleFilter} /> </div> <HotTable ref={hotTableComponentRef} data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} filters={true} height="auto" className="exampleQuickFilter" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> </> );};
export default ExampleComponent;.controlsQuickFilter { position: relative; z-index: 0; display: flex; align-items: center; gap: 0.75rem; margin: 0; padding: 0;}
#filterField { border: 1px solid var(--sl-color-gray-5); background: none; color: var(--sl-color-text); font-size: var(--sl-text-sm); padding: 0.4rem 0.625rem; outline: none; width: 140px;}
#filterField::placeholder { color: var(--sl-color-gray-3);}
#filterField:focus { border-color: var(--sl-color-accent);}
/* Filter dropdown */.filter-dropdown { position: relative; display: inline-flex; align-items: center; gap: 0.5rem;}
.filter-dropdown-label { color: var(--sl-color-gray-2); font-size: var(--sl-text-sm); white-space: nowrap;}
.filter-dropdown-trigger { display: inline-flex; align-items: center; gap: 0.5rem; background: none; border: 1px solid var(--sl-color-gray-5); color: var(--sl-color-gray-2); cursor: pointer; font-size: var(--sl-text-sm); font-weight: 500; padding: 0.4rem 0.625rem; transition: color 0.15s, background-color 0.15s; white-space: nowrap; border-radius: 0;}
.filter-dropdown-trigger:hover { color: var(--sl-color-white); background: var(--sl-color-gray-7, var(--sl-color-gray-6));}
.filter-dropdown-chevron { flex-shrink: 0; margin-inline-start: 0.15rem; transition: transform 0.15s;}
.filter-dropdown-trigger[aria-expanded='true'] .filter-dropdown-chevron { transform: rotate(180deg);}
.filter-dropdown-menu { background: var(--sl-color-bg-nav); border: 1px solid var(--sl-color-gray-5); border-radius: 0; box-shadow: none; inset-inline-start: 0; list-style: none; margin: 0; min-width: 100%; overflow-y: auto; padding: 0; position: absolute; top: 100%; z-index: 9999;}
.filter-dropdown-menu[hidden] { display: none !important;}
.filter-dropdown-menu li { align-items: center; color: var(--sl-color-text); display: flex; font-size: var(--sl-text-sm); padding: 0.5rem 0.75rem; cursor: pointer; border-bottom: 1px solid var(--sl-color-gray-5); transition: background 0.1s, color 0.1s; white-space: nowrap; list-style: none; margin: 0;}
.filter-dropdown-menu li:last-child { border-bottom: none;}
.filter-dropdown-menu li:hover,.filter-dropdown-menu li:focus-visible { background: var(--sl-color-gray-6); color: var(--sl-color-white); outline: none;}
.filter-dropdown-menu li[aria-selected='true'] { color: var(--sl-color-white); box-shadow: inset 0 0 0 1px var(--sl-color-accent);}Customize the filter button
The default button that opens the column menu can be styled with CSS by modifying
button.changeType variables and its ::before pseudoclass that contains svg mask-image displaying an arrow
down icon.
import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} // to differentiate this example's CSS from other examples on this page className="customFilterButtonExample1" height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} // to differentiate this example's CSS from other examples on this page className="customFilterButtonExample1" height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;.handsontable.customFilterButtonExample1 .changeType { --ht-icon-button-background-color: #e2e2e263; --ht-icon-button-border-radius: 100%;}
.handsontable.customFilterButtonExample1 .changeType::before { -webkit-mask-image: url("data:image/svg+xml,%3Csvg width=%2716%27 height=%2716%27 viewBox=%270 0 16 16%27 fill=%27none%27 xmlns=%27http://www.w3.org/2000/svg%27%3E%3Cpath d=%27M6.83337 7.99984C6.83337 8.30926 6.95629 8.606 7.17508 8.8248C7.39388 9.04359 7.69062 9.1665 8.00004 9.1665C8.30946 9.1665 8.60621 9.04359 8.825 8.8248C9.04379 8.606 9.16671 8.30926 9.16671 7.99984C9.16671 7.69042 9.04379 7.39367 8.825 7.17488C8.60621 6.95609 8.30946 6.83317 8.00004 6.83317C7.69062 6.83317 7.39388 6.95609 7.17508 7.17488C6.95629 7.39367 6.83337 7.69042 6.83337 7.99984Z%27 fill=%27%23222222%27/%3E%3Cpath d=%27M6.83337 12.4165C6.83337 12.7259 6.95629 13.0227 7.17508 13.2415C7.39388 13.4603 7.69062 13.5832 8.00004 13.5832C8.30946 13.5832 8.60621 13.4603 8.825 13.2415C9.04379 13.0227 9.16671 12.7259 9.16671 12.4165C9.16671 12.1071 9.04379 11.8103 8.825 11.5915C8.60621 11.3728 8.30946 11.2498 8.00004 11.2498C7.69062 11.2498 7.39388 11.3728 7.17508 11.5915C6.95629 11.8103 6.83337 12.1071 6.83337 12.4165Z%27 fill=%27%23222222%27/%3E%3Cpath d=%27M6.83337 3.58317C6.83337 3.89259 6.95629 4.18934 7.17508 4.40813C7.39388 4.62692 7.69062 4.74984 8.00004 4.74984C8.30946 4.74984 8.60621 4.62692 8.825 4.40813C9.04379 4.18934 9.16671 3.89259 9.16671 3.58317C9.16671 3.27375 9.04379 2.97701 8.825 2.75821C8.60621 2.53942 8.30946 2.4165 8.00004 2.4165C7.69062 2.4165 7.39388 2.53942 7.17508 2.75821C6.95629 2.97701 6.83337 3.27375 6.83337 3.58317Z%27 fill=%27currentColor%27/%3E%3C/svg%3E");}The column menu button is always visible, but if you want it to appear only when the mouse cursor is
over the header, apply additional styling to th .relative:hover .changeType.
import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} // to differentiate this example's CSS from other examples on this page className="customFilterButtonExample2" height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} // to differentiate this example's CSS from other examples on this page className="customFilterButtonExample2" height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;/* hide the column menu button by default */.customFilterButtonExample2 .changeType { visibility: hidden;}
/* show the column menu button on hover */.customFilterButtonExample2 th .relative:hover .changeType { visibility: visible;}Change the width of the filter menu
If the text data in your columns is too long to fit in the filters container, you can adjust the
column menu’s width for better user experience. You can achieve this with by styling
.htDropdownMenu table.htCore.
.handsontable .htDropdownMenu table.htCore { width: 300px !important;}Exclude rows from filtering
You can exclude any number of top or bottom rows from filtering.
In the following demo, the first and the last row are frozen, and filtering doesn’t affect them.
// you need `useRef` to call Handsontable's instance methodsimport { useRef } from 'react';import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { const hotTableComponentRef = useRef(null); const exclude = () => { const hotInstance = hotTableComponentRef.current?.hotInstance; // @ts-ignore const filtersRowsMap = hotInstance?.getPlugin('filters').filtersRowsMap;
filtersRowsMap.setValueAtIndex(0, false); filtersRowsMap.setValueAtIndex(filtersRowsMap.indexedValues.length - 1, false); };
return ( <HotTable ref={hotTableComponentRef} data={[ { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: 11, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: 0, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: 1, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '13:23', inStock: 3, }, { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: 5, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: 22, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: 13, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: 0, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '13:23', inStock: 14, }, { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: 16, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: 18, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: 3, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: 0, }, { brand: 'Vinte', model: 'ML Road Frame-W', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: 2, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, className: 'htRight', }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'numeric', data: 'inStock', className: 'htCenter', }, ]} height={200} colWidths={[120, 150, 120, 140, 120, 120]} fixedRowsTop={1} fixedRowsBottom={1} minSpareRows={1} colHeaders={true} filters={true} dropdownMenu={true} afterFilter={exclude} autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;// you need `useRef` to call Handsontable's instance methodsimport { useRef } from 'react';import { HotTable, HotTableRef } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { const hotTableComponentRef = useRef<HotTableRef>(null); const exclude = () => { const hotInstance = hotTableComponentRef.current?.hotInstance; // @ts-ignore const filtersRowsMap = hotInstance?.getPlugin('filters').filtersRowsMap;
filtersRowsMap.setValueAtIndex(0, false); filtersRowsMap.setValueAtIndex(filtersRowsMap.indexedValues.length - 1, false); };
return ( <HotTable ref={hotTableComponentRef} data={[ { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: 11, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: 0, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: 1, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '13:23', inStock: 3, }, { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: 5, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: 22, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: 13, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: 0, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '13:23', inStock: 14, }, { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: 16, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: 18, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: 3, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: 0, }, { brand: 'Vinte', model: 'ML Road Frame-W', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: 2, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, className: 'htRight', }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'numeric', data: 'inStock', className: 'htCenter', }, ]} height={200} colWidths={[120, 150, 120, 140, 120, 120]} fixedRowsTop={1} fixedRowsBottom={1} minSpareRows={1} colHeaders={true} filters={true} dropdownMenu={true} afterFilter={exclude} autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;Server-side filtering
You can decide to use Handsontable as an intuitive filtering interface, but perform the actual filtering on the server.
To help you with that, Handsontable’s beforeFilter() hook allows
you to:
- Gather information about the filters that the user wants to apply, to send it to the server.
- Disable filtering on the front end, so it doesn’t interfere with filtering on the server.
In the following demo, click on one of the column menu buttons (▼) and play around with filtering by selecting values or conditions-based criteria. After you click OK, the ▼ button turns green to indicate filtering, but the data is not filtered. Instead, the information about the specified filters is logged to the console.
import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" // `beforeFilter()` is a Handsontable hook // it's fired after Handsontable gathers information about the filters, but before the filters are applied beforeFilter={function (conditionsStack) { // gather information about the filters console.log(`The amount of filters: ${conditionsStack.length}`); console.log(`The last changed column index: ${conditionsStack[0].column}`); console.log(`The amount of filters added to this column: ${conditionsStack[0].conditions.length}`); // the list of filter conditions console.log(conditionsStack[0].conditions);
// return `false` to disable filtering on the client side return false; }} autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { return ( <HotTable data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" // `beforeFilter()` is a Handsontable hook // it's fired after Handsontable gathers information about the filters, but before the filters are applied beforeFilter={function (conditionsStack) { // gather information about the filters console.log(`The amount of filters: ${conditionsStack.length}`); console.log(`The last changed column index: ${conditionsStack[0].column}`); console.log(`The amount of filters added to this column: ${conditionsStack[0].conditions.length}`); // the list of filter conditions console.log(conditionsStack[0].conditions);
// return `false` to disable filtering on the client side return false; }} autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> );};
export default ExampleComponent;Control filtering programmatically
You can control filtering at the grid’s runtime by using Handsontable’s hooks and API methods. This allows you to enable or disable filtering based on specific conditions. For example, you may create a user interface outside of the grid to manage Handsontable’s filtering behavior.
Enable or disable filtering programmatically
To enable or disable filtering programmatically, use the
updateSettings() method.
const hotTableComponentRef = useRef(null);
hotTableComponentRef.current.hotInstance.updateSettings({ // enable filtering filters: true, // enable the column menu dropdownMenu: true,});
hotTableComponentRef.current.hotInstance.updateSettings({ // disable filtering filters: false,});You can also enable or disable filtering for specific columns. For example, to enable filtering only for the first column:
const hotTableComponentRef = useRef(null);
hotTableComponentRef.current.hotInstance.updateSettings({ // enable filtering for all columns filters: true, // enable the column menu for all columns // but display only the 'Filter by value' list and the 'OK' and // 'Cancel' buttons dropdownMenu: { items: { filter_by_value: { // hide the 'Filter by value' list from all columns but the // first one hidden() { return this.getSelectedRangeLast().to.col > 0; }, }, filter_action_bar: { // hide the 'OK' and 'Cancel' buttons from all columns but the // first one hidden() { return this.getSelectedRangeLast().to.col > 0; }, }, }, },});Filter data programmatically
To filter data programmatically, use the Filters plugin’s API. Remember to
enable filtering first.
Mind that before you apply new filter conditions, you need to clear the previous ones with
filters.clearConditions().
import { useRef } from 'react';import { HotTable } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { const hotTableComponentRef = useRef(null); const filterBelow200 = () => { // get the `Filters` plugin, so you can use its API const filters = hotTableComponentRef.current?.hotInstance?.getPlugin('filters');
// clear any existing filters filters?.clearConditions(); // filter data by the 'Price' column (column at index 2) // to display only items that are less than ('lt') $200 filters?.addCondition(2, 'lt', [200]); filters?.filter(); };
const filterAbove200 = () => { // get the `Filters` plugin, so you can use its API const filters = hotTableComponentRef.current?.hotInstance?.getPlugin('filters');
filters?.clearConditions(); // display only items that are more than ('gt') $200 filters?.addCondition(2, 'gt', [200]); filters?.filter(); };
const clearAllFilters = () => { // get the `Filters` plugin, so you can use its API const filters = hotTableComponentRef.current?.hotInstance?.getPlugin('filters');
// clear all filters filters?.clearConditions(); filters?.filter(); };
return ( <> <div className="controls"> <button onClick={filterBelow200}>Show items < $200</button> <button onClick={filterAbove200}>Show items > $200</button> <button onClick={clearAllFilters}>Clear filters</button> </div> <HotTable ref={hotTableComponentRef} data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> </> );};
export default ExampleComponent;import { useRef } from 'react';import { HotTable, HotTableRef } from '@handsontable/react-wrapper';import { registerAllModules } from 'handsontable/registry';
// register Handsontable's modulesregisterAllModules();
const ExampleComponent = () => { const hotTableComponentRef = useRef<HotTableRef>(null); const filterBelow200 = () => { // get the `Filters` plugin, so you can use its API const filters = hotTableComponentRef.current?.hotInstance?.getPlugin('filters');
// clear any existing filters filters?.clearConditions(); // filter data by the 'Price' column (column at index 2) // to display only items that are less than ('lt') $200 filters?.addCondition(2, 'lt', [200]); filters?.filter(); };
const filterAbove200 = () => { // get the `Filters` plugin, so you can use its API const filters = hotTableComponentRef.current?.hotInstance?.getPlugin('filters');
filters?.clearConditions(); // display only items that are more than ('gt') $200 filters?.addCondition(2, 'gt', [200]); filters?.filter(); };
const clearAllFilters = () => { // get the `Filters` plugin, so you can use its API const filters = hotTableComponentRef.current?.hotInstance?.getPlugin('filters');
// clear all filters filters?.clearConditions(); filters?.filter(); };
return ( <> <div className="controls"> <button onClick={filterBelow200}>Show items < $200</button> <button onClick={filterAbove200}>Show items > $200</button> <button onClick={clearAllFilters}>Clear filters</button> </div> <HotTable ref={hotTableComponentRef} data={[ { brand: 'Jetpulse', model: 'Racing Socks', price: 30, sellDate: '2023-10-11', sellTime: '01:23', inStock: false, }, { brand: 'Gigabox', model: 'HL Mountain Frame', price: 1890.9, sellDate: '2023-05-03', sellTime: '11:27', inStock: false, }, { brand: 'Camido', model: 'Cycling Cap', price: 130.1, sellDate: '2023-03-27', sellTime: '03:17', inStock: true, }, { brand: 'Chatterpoint', model: 'Road Tire Tube', price: 59, sellDate: '2023-08-28', sellTime: '08:01', inStock: true, }, { brand: 'Eidel', model: 'HL Road Tire', price: 279.99, sellDate: '2023-10-02', sellTime: '01:23', inStock: true, }, ]} columns={[ { title: 'Brand', type: 'text', data: 'brand', }, { title: 'Model', type: 'text', data: 'model', }, { title: 'Price', type: 'numeric', data: 'price', locale: 'en-US', numericFormat: { style: 'currency', currency: 'USD', minimumFractionDigits: 2, }, }, { title: 'Date', type: 'intl-date', data: 'sellDate', locale: 'en-US', dateFormat: { month: 'short', day: 'numeric', year: 'numeric' }, className: 'htRight', }, { title: 'Time', type: 'intl-time', data: 'sellTime', locale: 'en-US', timeFormat: { hour: '2-digit', minute: '2-digit', hour12: true }, className: 'htRight', }, { title: 'In stock', type: 'checkbox', data: 'inStock', className: 'htCenter', }, ]} // enable filtering filters={true} // enable the column menu dropdownMenu={true} height="auto" autoWrapRow={true} autoWrapCol={true} licenseKey="non-commercial-and-evaluation" /> </> );};
export default ExampleComponent;Import the filtering module
You can reduce the size of your bundle by importing and registering only the modules that you need.
To use filtering, you need only the following modules:
- The base module
- The
Filtersmodule - The
DropdownMenumodule
// import the base moduleimport Handsontable from 'handsontable/base';
// import the filtering pluginsimport { registerPlugin, Filters, DropdownMenu } from 'handsontable/plugins';
// register the filtering pluginsregisterPlugin(Filters);registerPlugin(DropdownMenu);Known limitations
At the moment, filtering comes with the following limitations:
- There is no easy way to add custom filter operators to the user interface.
- The list of values that you can filter by is generated automatically and there’s no supported way of modifying it.
- The filter’s dropdown menu has a limited capacity per column: at most 2 regular conditions and 1
“filter by value” condition. If you add more conditions programmatically via
addCondition(), the extra conditions are applied to the data but are not visible or editable in the dropdown menu.
Related keyboard shortcuts
| Windows | macOS | Action | Excel | Sheets |
|---|---|---|---|---|
| Alt+A | Option+A | Clear all filters | ✗ | ✗ |
API reference
For the list of options, methods, and Handsontable hooks related to filtering, see the following API reference pages:
Plugins
Troubleshooting
Didn’t find what you need? Try this: