RTL support
Handsontable library doesn't support RTL direction at the moment. The library will be updated once dev team adds it.
Basic configuration

Handsontable is a data grid component with an Excel-like appearance. Built in JavaScript, it integrates with any data source with peak efficiency. It comes with powerful features like data validation, sorting, grouping, data binding, formula support or column ordering. This example demonstrates a very basic configuration with enabled columns and rows header. Cells are generated with handsontable helper.

MercedesGL5002009blue32500
ChevroletCamaro2012red42400
DodgeCharger2011white24900
HummerH32014black54000
ChevroletTahoe2009purple29300
ToyotaLand Cruiser2007lime54500
NissanGTR2009cyan44900
PorscheCayenne2012yellow35000
VolkswagenTouareg2010crimson41000
BMWX52010orange48800
AudiQ72009green21000
CadillacEscalade2012silver63900
Column headers

The following example demonstrates headers added to the table columns. To add columns with default letters count, set colHeaders option to true in the table configuration. If a function is set, the index of the column is passed as a parameter. If table doesn't have scrolling, headers are fixed to the top of the page when scrolling the page. Otherwise headers are sticked to the top of table's container.

A
B
C
D
E
MercedesGL5002009blue32500
ChevroletCamaro2012red42400
DodgeCharger2011white24900
HummerH32014black54000
ChevroletTahoe2009purple29300
ToyotaLand Cruiser2007lime54500
NissanGTR2009cyan44900
PorscheCayenne2012yellow35000
VolkswagenTouareg2010crimson41000
BMWX52010orange48800
AudiQ72009green21000
CadillacEscalade2012silver63900
A
B
C
D
E
Row headers

The following example demonstrates headers added to the table rows. To add rows with default letters count, set rowHeaders option to true in the table configuration. If a function is set, the index of the column is passed as a parameter. If table has horizontal scrolling, row headers column is sticked to the left of table's container.

 
A
B
C
D
E
1
MercedesGL5002009blue32500
2
ChevroletCamaro2012red42400
3
DodgeCharger2011white24900
4
HummerH32014black54000
5
ChevroletTahoe2009purple29300
6
ToyotaLand Cruiser2007lime54500
7
NissanGTR2009cyan44900
8
PorscheCayenne2012yellow35000
9
VolkswagenTouareg2010crimson41000
10
BMWX52010orange48800
11
AudiQ72009green21000
12
CadillacEscalade2012silver63900
 
A
B
C
D
E
 
1
2
3
4
5
6
7
8
9
10
11
12
 
Custom header text

The following example demonstrates rows and columns headers with custom text using colHeaders and rowHeaders options. Setting true or false will enable or disable the default column headers (A, B, C). You can also define an array ['One', 'Two', 'Three', ...] or a function to define the headers. If a function is set the index of the column is passed as a parameter.

 
Brand
Model
Year
Color
Price
1
MercedesGL5002009blue32500
2
ChevroletCamaro2012red42400
3
DodgeCharger2011white24900
4
HummerH32014black54000
5
ChevroletTahoe2009purple29300
6
ToyotaLand Cruiser2007lime54500
7
NissanGTR2009cyan44900
8
PorscheCayenne2012yellow35000
9
VolkswagenTouareg2010crimson41000
10
BMWX52010orange48800
11
AudiQ72009green21000
12
CadillacEscalade2012silver63900
 
Brand
Model
Year
Color
Price
 
1
2
3
4
5
6
7
8
9
10
11
12
 
Comments

The following example demonstrates optional comments added to the specified cell using comments option. Setting this option to true allows you to add and remove cell comments through the context menu. To initialize Handsontable with predefined comments, provide comment cell property: {row: 1, col: 1, comment: "Test comment"}. HTML content isn't supported at the moment.

 
A
B
C
D
E
1
MercedesGL5002009blue32500
2
ChevroletCamaro2012red42400
3
DodgeCharger2011white24900
4
HummerH32014black54000
5
ChevroletTahoe2009purple29300
6
ToyotaLand Cruiser2007lime54500
7
NissanGTR2009cyan44900
8
PorscheCayenne2012yellow35000
9
VolkswagenTouareg2010crimson41000
10
BMWX52010orange48800
11
AudiQ72009green21000
12
CadillacEscalade2012silver63900
 
A
B
C
D
E
 
1
2
3
4
5
6
7
8
9
10
11
12
 
Custom borders

This example demonstrates custom border options: range, sizes, width and color. If customBorders is set to true, enables Custom Borders plugin, which enables applying custom borders through the context menu (configurable with context menu key borders). To initialize Handsontable with predefined custom borders, provide cell coordinates and border styles in form of an array.

 
A
B
C
D
E
F
G
H
I
J
1
A1B1C1D1E1F1G1H1I1J1
2
A2B2C2D2E2F2G2H2I2J2
3
A3B3C3D3E3F3G3H3I3J3
4
A4B4C4D4E4F4G4H4I4J4
5
A5B5C5D5E5F5G5H5I5J5
6
A6B6C6D6E6F6G6H6I6J6
7
A7B7C7D7E7F7G7H7I7J7
8
A8B8C8D8E8F8G8H8I8J8
9
A9B9C9D9E9F9G9H9I9J9
10
A10B10C10D10E10F10G10H10I10J10
11
A11B11C11D11E11F11G11H11I11J11
12
A12B12C12D12E12F12G12H12I12J12
13
A13B13C13D13E13F13G13H13I13J13
14
A14B14C14D14E14F14G14H14I14J14
15
A15B15C15D15E15F15G15H15I15J15
16
A16B16C16D16E16F16G16H16I16J16
17
A17B17C17D17E17F17G17H17I17J17
18
A18B18C18D18E18F18G18H18I18J18
19
A19B19C19D19E19F19G19H19I19J19
20
A20B20C20D20E20F20G20H20I20J20
21
A21B21C21D21E21F21G21H21I21J21
22
A22B22C22D22E22F22G22H22I22J22
23
A23B23C23D23E23F23G23H23I23J23
24
A24B24C24D24E24F24G24H24I24J24
25
A25B25C25D25E25F25G25H25I25J25
26
A26B26C26D26E26F26G26H26I26J26
27
A27B27C27D27E27F27G27H27I27J27
28
A28B28C28D28E28F28G28H28I28J28
29
A29B29C29D29E29F29G29H29I29J29
30
A30B30C30D30E30F30G30H30I30J30
31
A31B31C31D31E31F31G31H31I31J31
32
A32B32C32D32E32F32G32H32I32J32
33
A33B33C33D33E33F33G33H33I33J33
 
A
B
C
D
E
F
G
H
I
J
1
A1B1C1D1E1F1G1H1I1J1
2
A2B2C2D2E2F2G2H2I2J2
 
A
B
1
A1B1
2
A2B2
3
A3B3
4
A4B4
5
A5B5
6
A6B6
7
A7B7
8
A8B8
9
A9B9
10
A10B10
11
A11B11
12
A12B12
13
A13B13
14
A14B14
15
A15B15
16
A16B16
17
A17B17
18
A18B18
19
A19B19
20
A20B20
21
A21B21
22
A22B22
23
A23B23
24
A24B24
25
A25B25
26
A26B26
27
A27B27
28
A28B28
29
A29B29
30
A30B30
31
A31B31
32
A32B32
33
A33B33
 
A
B
1
A1B1
2
A2B2