There is a newer version of Handsontable available. Switch to the latest version ⟶
JavaScript Data Grid Column virtualization
Render hundreds of columns without freezing the browser, using column virtualization.
Overview
To process a large number of columns in a browser Handsontable utilizes the virtualization process to display only the visible part of the grid with a small offset for a better scrolling experience. This feature is turned on by default and can be turned off only for rows, not columns.
Configure the column virtualization
You can experiment with the viewportColumnRenderingOffset
config option, which determines the number of columns being displayed outside the visible viewport. If the number passed to that option is greater than the total columns in your data set, the virtualization will be practically turned off.
To make the grid scrollable, set the constant width and height to same as the container holding Handsontable and height and set the overflow
property to hidden
in the container's stylesheet. If the table contains enough rows or columns, it will be scrollable.
The scrolling performance depends mainly on four factors:
- Number of cells - number of rows multiplied by the number of columns
- Amount and complexity of custom renderers in cells
- Number of options enabled in the configuration
- Performance of your setup - physical machine and browser
The demo below presents a data grid displaying one million cells (1000 rows x 1000 columns).
A | B | C | D | E | F | G | H | I | J | K | L | M | N | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | 0, 0 | 0, 1 | 0, 2 | 0, 3 | 0, 4 | 0, 5 | 0, 6 | 0, 7 | 0, 8 | 0, 9 | 0, 10 | 0, 11 | 0, 12 | 0, 13 |
2 | 1, 0 | 1, 1 | 1, 2 | 1, 3 | 1, 4 | 1, 5 | 1, 6 | 1, 7 | 1, 8 | 1, 9 | 1, 10 | 1, 11 | 1, 12 | 1, 13 |
3 | 2, 0 | 2, 1 | 2, 2 | 2, 3 | 2, 4 | 2, 5 | 2, 6 | 2, 7 | 2, 8 | 2, 9 | 2, 10 | 2, 11 | 2, 12 | 2, 13 |
4 | 3, 0 | 3, 1 | 3, 2 | 3, 3 | 3, 4 | 3, 5 | 3, 6 | 3, 7 | 3, 8 | 3, 9 | 3, 10 | 3, 11 | 3, 12 | 3, 13 |
5 | 4, 0 | 4, 1 | 4, 2 | 4, 3 | 4, 4 | 4, 5 | 4, 6 | 4, 7 | 4, 8 | 4, 9 | 4, 10 | 4, 11 | 4, 12 | 4, 13 |
6 | 5, 0 | 5, 1 | 5, 2 | 5, 3 | 5, 4 | 5, 5 | 5, 6 | 5, 7 | 5, 8 | 5, 9 | 5, 10 | 5, 11 | 5, 12 | 5, 13 |
7 | 6, 0 | 6, 1 | 6, 2 | 6, 3 | 6, 4 | 6, 5 | 6, 6 | 6, 7 | 6, 8 | 6, 9 | 6, 10 | 6, 11 | 6, 12 | 6, 13 |
8 | 7, 0 | 7, 1 | 7, 2 | 7, 3 | 7, 4 | 7, 5 | 7, 6 | 7, 7 | 7, 8 | 7, 9 | 7, 10 | 7, 11 | 7, 12 | 7, 13 |
9 | 8, 0 | 8, 1 | 8, 2 | 8, 3 | 8, 4 | 8, 5 | 8, 6 | 8, 7 | 8, 8 | 8, 9 | 8, 10 | 8, 11 | 8, 12 | 8, 13 |
10 | 9, 0 | 9, 1 | 9, 2 | 9, 3 | 9, 4 | 9, 5 | 9, 6 | 9, 7 | 9, 8 | 9, 9 | 9, 10 | 9, 11 | 9, 12 | 9, 13 |
11 | 10, 0 | 10, 1 | 10, 2 | 10, 3 | 10, 4 | 10, 5 | 10, 6 | 10, 7 | 10, 8 | 10, 9 | 10, 10 | 10, 11 | 10, 12 | 10, 13 |
12 | 11, 0 | 11, 1 | 11, 2 | 11, 3 | 11, 4 | 11, 5 | 11, 6 | 11, 7 | 11, 8 | 11, 9 | 11, 10 | 11, 11 | 11, 12 | 11, 13 |
13 | 12, 0 | 12, 1 | 12, 2 | 12, 3 | 12, 4 | 12, 5 | 12, 6 | 12, 7 | 12, 8 | 12, 9 | 12, 10 | 12, 11 | 12, 12 | 12, 13 |
14 | 13, 0 | 13, 1 | 13, 2 | 13, 3 | 13, 4 | 13, 5 | 13, 6 | 13, 7 | 13, 8 | 13, 9 | 13, 10 | 13, 11 | 13, 12 | 13, 13 |
15 | 14, 0 | 14, 1 | 14, 2 | 14, 3 | 14, 4 | 14, 5 | 14, 6 | 14, 7 | 14, 8 | 14, 9 | 14, 10 | 14, 11 | 14, 12 | 14, 13 |
A | B | C | D | E | F | G | H | I | J | K | L | M | N |
---|
1 |
---|
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
Related articles
Related guides
Related API reference
- Configuration options: