Group of Rows
Jspreadsheet allows the creation of collapsible groups of rows, which can help manage the available space in the workspace and quickly show or hide the rows within the group. This feature can be helpful when dealing with large datasets or when you want to organize similar rows more compactly and efficiently.
Documentation
Methods
You can programmatically use one of the following methods to manage and interact with the group of rows feature.
Method | Description |
---|---|
getRowGroup() | Get all row groups.getRowGroup() : object |
setRowGroup(number, number) | Create a new collapsable group of rows.setRowGroup(rowNumber: Number, numOfItems: Number) : void |
resetRowGroup(number) | Reset the row group.resetRowGroup(rowNumber: Number) : void |
openRowGroup(number) | Open a group of rows.openRowGroup(rowNumber: Number) : void |
closeRowGroup(number) | Close a group of rows.closeRowGroup(rowNumber: Number) : void |
Events
The following are the available event methods related to the row grouping feature.
Property | Description |
---|---|
ongrouprow | When the user creates, updates or reset a group of rowsoncreaterowgroup?: (worksheet: Object, row: Number, numOfItems: Number) => void |
onopenrowgroup | When the user opens a group of rowsonopenrowgroup?: (worksheet: Object, row: Number) => void |
oncloserowgroup | When the user closes a group of rowsoncloserowgroup?: (worksheet: Object, row: Number) => void |
Initial Settings
You can use one of the following properties to configure the data grid to display specific sets of rows upon initialization.
Property | Description |
---|---|
group?: number | The number of rows. |
state?: boolean | Initial state of this group. Default: false (closed) |
Examples
Basic collapsable row group.
How to create a data grid collapse rows on Jspreadsheet.
Sort smallest to largest
Sort largest to smallest
A | B | C | D | E | F | G | H | I | |
---|---|---|---|---|---|---|---|---|---|
1 | A1 | B1 | C1 | D1 | E1 | F1 | G1 | H1 | I1 |
2 | A2 | B2 | C2 | D2 | E2 | F2 | G2 | H2 | I2 |
3 | A3 | B3 | C3 | D3 | E3 | F3 | G3 | H3 | I3 |
4 | A4 | B4 | C4 | D4 | E4 | F4 | G4 | H4 | I4 |
5 | A5 | B5 | C5 | D5 | E5 | F5 | G5 | H5 | I5 |
6 | A6 | B6 | C6 | D6 | E6 | F6 | G6 | H6 | I6 |
7add | A7 | B7 | C7 | D7 | E7 | F7 | G7 | H7 | I7 |
11 | A11 | B11 | C11 | D11 | E11 | F11 | G11 | H11 | I11 |
12 | A12 | B12 | C12 | D12 | E12 | F12 | G12 | H12 | I12 |
13 | A13 | B13 | C13 | D13 | E13 | F13 | G13 | H13 | I13 |
14 | A14 | B14 | C14 | D14 | E14 | F14 | G14 | H14 | I14 |
15 | A15 | B15 | C15 | D15 | E15 | F15 | G15 | H15 | I15 |
16 | A16 | B16 | C16 | D16 | E16 | F16 | G16 | H16 | I16 |
17 | A17 | B17 | C17 | D17 | E17 | F17 | G17 | H17 | I17 |
18 | A18 | B18 | C18 | D18 | E18 | F18 | G18 | H18 | I18 |
19 | A19 | B19 | C19 | D19 | E19 | F19 | G19 | H19 | I19 |
20 | A20 | B20 | C20 | D20 | E20 | F20 | G20 | H20 | I20 |
21 | A21 | B21 | C21 | D21 | E21 | F21 | G21 | H21 | I21 |
22 | A22 | B22 | C22 | D22 | E22 | F22 | G22 | H22 | I22 |
23 | A23 | B23 | C23 | D23 | E23 | F23 | G23 | H23 | I23 |
<html>
<script src="https://jspreadsheet.com/v11/jspreadsheet.js"></script>
<script src="https://jsuites.net/v5/jsuites.js"></script>
<link rel="stylesheet" href="https://jsuites.net/v5/jsuites.css" type="text/css" />
<link rel="stylesheet" href="https://jspreadsheet.com/v11/jspreadsheet.css" type="text/css" />
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Material+Icons" />
<div id="spreadsheet"></div>
<p><input type="button" value="setRowGroup(0,3)" id="btn1" />
<input type="button" value="resetRowGroup(0)" id="btn2" /></p>
<script>
// Set your JSS license key (The following key only works for one day)
jspreadsheet.setLicense('OTQ5NzE2NmIyNzIxZDkxZGM5ZjJlMTk0MWRjZjQ2YjQwY2JhN2JmOWUzMmUyZDMxOWY2OWQ5YWVhYjI0MjdlNGVlOTVkYjEwMDkzZjBkZjc1MjI2YzE5MjI3MTI3NDQyN2UxNTAyNmYwZWJkMWVhOGY0ZDkxN2ZkM2ZmYjhhMDgsZXlKamJHbGxiblJKWkNJNklpSXNJbTVoYldVaU9pSktjM0J5WldGa2MyaGxaWFFpTENKa1lYUmxJam94TnpRek9ERXhOVGczTENKa2IyMWhhVzRpT2xzaWFuTndjbVZoWkhOb1pXVjBMbU52YlNJc0ltTnZaR1Z6WVc1a1ltOTRMbWx2SWl3aWFuTm9aV3hzTG01bGRDSXNJbU56WWk1aGNIQWlMQ0ozWldJaUxDSnNiMk5oYkdodmMzUWlYU3dpY0d4aGJpSTZJak0wSWl3aWMyTnZjR1VpT2xzaWRqY2lMQ0oyT0NJc0luWTVJaXdpZGpFd0lpd2lkakV4SWl3aVkyaGhjblJ6SWl3aVptOXliWE1pTENKbWIzSnRkV3hoSWl3aWNHRnljMlZ5SWl3aWNtVnVaR1Z5SWl3aVkyOXRiV1Z1ZEhNaUxDSnBiWEJ2Y25SbGNpSXNJbUpoY2lJc0luWmhiR2xrWVhScGIyNXpJaXdpYzJWaGNtTm9JaXdpY0hKcGJuUWlMQ0p6YUdWbGRITWlMQ0pqYkdsbGJuUWlMQ0p6WlhKMlpYSWlMQ0p6YUdGd1pYTWlYU3dpWkdWdGJ5STZkSEoxWlgwPQ==');
// Create the data
// Data
let data = [];
for (let j = 0; j < 50; j++) {
data[j] = [];
for (let i = 0; i < 50; i++) {
data[j][i] = jspreadsheet.helpers.getColumnNameFromCoords(i, j);
}
}
// Create a new spreadsheet
let spreadsheet = jspreadsheet(document.getElementById('spreadsheet'), {
worksheets: [{
data: data,
tableOverflow: true,
tableWidth: '800px',
tableHeight: '400px',
rows: { 6: { group: 3 }},
}]
});
document.getElementById("btn1").onclick = () => spreadsheet[0].setRowGroup(0,3);
document.getElementById("btn2").onclick = () => spreadsheet[0].resetRowGroup(0);
</script>
</html>