MRT logoMaterial React Table

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.


Demo

Open Code SandboxOpen on GitHub
First Name
Last Name
Address
City
State
JohnDoe261 Erdman FordEast DaphneKentucky
JaneDoe769 Dominic GroveColumbusOhio
JoeDoe566 Brakus InletSouth LindaWest Virginia
KevinVandy722 Emie StreamLincolnNebraska
JoshuaRolluffs32188 Larkin TurnpikeOmahaNebraska

Linhas por página

1-5 de 5

Source Code

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';
4
5type Person = {
6 name: {
7 firstName: string;
8 lastName: string;
9 };
10 address: string;
11 city: string;
12 state: string;
13};
14
15//nested data is ok, see accessorKeys in ColumnDef below
16const 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];
63
64const Example: FC = () => {
65 //should be memoized or stable
66 const columns = useMemo<MRT_ColumnDef<Person>[]>(
67 () => [
68 {
69 accessorKey: 'name.firstName', //access nested data with dot notation
70 header: 'First Name',
71 },
72 {
73 accessorKey: 'name.lastName',
74 header: 'Last Name',
75 },
76 {
77 accessorKey: 'address', //normal accessorKey
78 header: 'Address',
79 },
80 {
81 accessorKey: 'city',
82 header: 'City',
83 },
84 {
85 accessorKey: 'state',
86 header: 'State',
87 },
88 ],
89 [],
90 );
91
92 return (
93 <MaterialReactTable
94 columns={columns}
95 data={data}
96 localization={MRT_Localization_PT_BR}
97 />
98 );
99};
100
101export default Example;
102

View Extra Storybook Examples