Basic Example
Material React Table enables client-side sorting, filtering, search, pagination, column hiding, and more by default. These features can easily be disabled or customized further, but here is a showcase of their default behavior. Be sure to check out a more Advanced Example to see how more features can be customized.
First Name | Last Name | Address | City | State |
---|---|---|---|---|
John | Doe | 261 Erdman Ford | East Daphne | Kentucky |
Jane | Doe | 769 Dominic Grove | Columbus | Ohio |
Joe | Doe | 566 Brakus Inlet | South Linda | West Virginia |
Kevin | Vandy | 722 Emie Stream | Lincoln | Nebraska |
Joshua | Rolluffs | 32188 Larkin Turnpike | Omaha | Nebraska |
1import React, { FC, useMemo } from 'react';2import MaterialReactTable, { MRT_ColumnDef } from 'material-react-table';3import { MRT_Localization_PT_BR } from 'material-react-table/locales/pt-BR';45type Person = {6 name: {7 firstName: string;8 lastName: string;9 };10 address: string;11 city: string;12 state: string;13};1415//nested data is ok, see accessorKeys in ColumnDef below16const data: Person[] = [17 {18 name: {19 firstName: 'John',20 lastName: 'Doe',21 },22 address: '261 Erdman Ford',23 city: 'East Daphne',24 state: 'Kentucky',25 },26 {27 name: {28 firstName: 'Jane',29 lastName: 'Doe',30 },31 address: '769 Dominic Grove',32 city: 'Columbus',33 state: 'Ohio',34 },35 {36 name: {37 firstName: 'Joe',38 lastName: 'Doe',39 },40 address: '566 Brakus Inlet',41 city: 'South Linda',42 state: 'West Virginia',43 },44 {45 name: {46 firstName: 'Kevin',47 lastName: 'Vandy',48 },49 address: '722 Emie Stream',50 city: 'Lincoln',51 state: 'Nebraska',52 },53 {54 name: {55 firstName: 'Joshua',56 lastName: 'Rolluffs',57 },58 address: '32188 Larkin Turnpike',59 city: 'Omaha',60 state: 'Nebraska',61 },62];6364const Example: FC = () => {65 //should be memoized or stable66 const columns = useMemo<MRT_ColumnDef<Person>[]>(67 () => [68 {69 accessorKey: 'name.firstName', //access nested data with dot notation70 header: 'First Name',71 },72 {73 accessorKey: 'name.lastName',74 header: 'Last Name',75 },76 {77 accessorKey: 'address', //normal accessorKey78 header: 'Address',79 },80 {81 accessorKey: 'city',82 header: 'City',83 },84 {85 accessorKey: 'state',86 header: 'State',87 },88 ],89 [],90 );9192 return (93 <MaterialReactTable94 columns={columns}95 data={data}96 localization={MRT_Localization_PT_BR}97 />98 );99};100101export default Example;102
View Extra Storybook Examples