-
Notifications
You must be signed in to change notification settings - Fork 426
Handling selection
Selecting cells in SlickGrid is handled by a selection model.
Selection models are controllers responsible for handling user interactions and notifying subscribers of the changes in the selection. Selection is represented as an array of Slick.Range objects.
You can get the current selection model from the grid by calling getSelectionModel()
and set a different one using setSelectionModel(selectionModel).
By default, no selection model is set. See Row Selection for an example of enabling it.
The grid also provides two helper methods to simplify development - getSelectedRows()
and setSelectedRows(rowsArray)
, as well as an onSelectedRowsChanged
event.
SlickGrid includes two pre-made selection models - Slick.CellSelectionModel
and Slick.RowSelectionModel
, but you can easily write a custom one.
A selection model must expose:
init
function init(grid)
An initializer function that will be called with an instance of the grid whenever a selection model is registered with setSelectionModel. The selection model can use this to initialize its state and subscribe to grid events.
destroy
function destroy()
A destructor function that will be called whenever a selection model is unregistered from the grid by a call to setSelectionModel with another selection model or whenever a grid with this selection model is destroyed. The selection model can use this destructor to unsubscribe from grid events and release all resources (remove DOM nodes, event listeners, etc.).
onSelectedRangesChanged
Slick.Event
An event that is fired whenever the selected ranges are changed. When a selection model is registered with the grid, the grid will subscribe to this event and use it to update the internal state and decorate selected cells with selectedCellCssClass. The event must be fired with the following data in event args:
- ranges - An array of Slick.Range objects representing the selection.
Below is a simplistic example of a single cell selection model that only reacts to mouse clicks:
function SingleCellSelectionModel() {
var self = this;
this.init = function(grid) {
self._grid = grid;
self._grid.onClick.subscribe(self.handleGridClick);
};
this.destroy = function() {
self._grid.onClick.unsubscribe(self.handleGridClick);
};
this.handleGridClick = function(e, args) {
var cell = self._grid.getCellFromEvent(e);
if (!cell || !self._grid.canCellBeSelected(cell.row, cell.cell)) {
return;
}
self.onSelectedRangesChanged.notify([new Slick.Range(cell.row, cell.cell, cell.row, cell.cell)]);
};
}
To enable the included row selection plugin, do the following:
/* In your html head */
<script src="path/to/SlickGrid/plugins/slick.rowselectionmodel.js"></script>
/* In your javascript file */
slickGrid.setSelectionModel(new Slick.RowSelectionModel());
slickGrid.init();
/* In your css file (or you can use a default theme that has this selector) */
.slick-cell.selected {
background-color: #FBB;
}
SlickGrid Repo
- Home
- The SlickGrid Manifesto
- The SlickGrid Community
- BugFix List
- Enhancement List
- Sharing Sample Pages
- Announcement & Migration to 3.0.0
- Announcement & Migration to 4.0.0
- Announcement & Migration to 5.0.0
Jump Start
Resources
- API Reference
- Grid
- Grid Options
- Auto Column Sizing
- Column Options
- Grid Events
- DataView
- DataView Events
- Providing data to the grid
- Plugins & Third-party packages
- CSP Compliance
Learning
Tests
Contact/Support