Row Numbers Feature Guide
Material React Table has an easy to implement row number features. There are two row number modes that you can enable. You can have row numbers that are associated with the data in the table (original mode), or you can have row numbers that are just statically part of the table (static mode).
Relevant Table Options
# | Prop Name 2 | Type | Default Value | More Info Links | |
---|---|---|---|---|---|
1 |
| Row Numbers Feature Guide | |||
2 |
|
| |||
Enable Row Numbers (Static Mode)
In the default rowNumberMode (static
), row numbers are just a static part of the table in their own column. They act like the row numbers in an excel spreadsheet. Sorting and filtering will not affect the row numbers.
# | First Name | Last Name | Address | City | State |
---|---|---|---|---|---|
1 | Dylan | Murray | 261 Erdman Ford | East Daphne | Kentucky |
2 | Raquel | Kohler | 769 Dominic Grove | Columbus | Ohio |
3 | Ervin | Reinger | 566 Brakus Inlet | South Linda | West Virginia |
4 | Brittany | McCullough | 722 Emie Stream | Lincoln | Nebraska |
5 | Branson | Frami | 32188 Larkin Turnpike | Charleston | South Carolina |
1import React, { useMemo } from 'react';2import { MaterialReactTable, type MRT_ColumnDef } from 'material-react-table';3import { data, type Person } from './makeData';45const Example = () => {6 const columns = useMemo<MRT_ColumnDef<Person>[]>(7 () => [8 //column definitions...30 ],3132 [],33 );3435 return (36 <MaterialReactTable37 columns={columns}38 data={data}39 enableRowNumbers40 rowNumberMode="static"41 />42 );43};4445export default Example;46
Enable Row Numbers (Original Mode)
Alternatively, use the "original"
rowNumberMode to have row numbers linked to the original index of the data array. This means that when you search or filter, the same row numbers will stay with the same rows as data is sorted and filtered.
# | First Name | Last Name | Address | City | State |
---|---|---|---|---|---|
1 | Dylan | Murray | 261 Erdman Ford | East Daphne | Kentucky |
2 | Raquel | Kohler | 769 Dominic Grove | Columbus | Ohio |
3 | Ervin | Reinger | 566 Brakus Inlet | South Linda | West Virginia |
4 | Brittany | McCullough | 722 Emie Stream | Lincoln | Nebraska |
5 | Branson | Frami | 32188 Larkin Turnpike | Charleston | South Carolina |
1import React, { useMemo } from 'react';2import { MaterialReactTable, type MRT_ColumnDef } from 'material-react-table';3import { data, type Person } from './makeData';45const Example = () => {6 const columns = useMemo<MRT_ColumnDef<Person>[]>(7 //column definitions...32 );3334 return (35 <MaterialReactTable36 columns={columns}37 data={data}38 enableRowNumbers39 rowNumberMode="original" //default40 />41 );42};4344export default Example;45
View Extra Storybook Examples