Cell Selection
The Grid component supports single or multiple cell selection. You can select a cell with mouse click anywhere in the cell. You can access the collection of selected cells, use this collection and manipulate it. You can subscribe to selection events.
Basics
To select a cell, click anywhere in it.
To select a range of cells in one or more columns, hold the Shift key, while clicking on the first and last cell of the range. To select or deselect multiple cells that don't belong to a range, hold the Ctrl key.
You can also select a cell range by holding and dragging the mouse cursor. The dragging motion defines the diagonal of a rectangle and the Grid will select the cells under this rectangle. To allow this kind of cell selection, set the DragToSelect
parameter in GridSelectionSettings
. The Shift and Ctrl modifiers are not supported in drag-to-select mode.
To enable cell selection:
- Set the Grid
SelectedCells
parameter to a collection of typeIEnumerable<GridSelectedCellDescriptor>
. The collection must be initialized in advance. SeeGridSelectedCellDescriptor
for infomation about the object properties. - Add a
<GridSelectionSettings>
tag to the<GridSettings>
tag, and set theSelectionType
parameter to theGridSelectionType.Cell
.
<TelerikGrid Data="@GridData"
SelectionMode="@GridSelectionMode.Multiple"
@bind-SelectedCells="@SelectedCells"
Pageable="true">
<GridSettings>
<GridSelectionSettings SelectionType="@GridSelectionType.Cell" DragToSelect="true" />
</GridSettings>
<GridColumns>
<GridColumn Field="@nameof(Employee.Name)" />
<GridColumn Field="@nameof(Employee.Team)" />
</GridColumns>
</TelerikGrid>
<h3>Selected Cells:</h3>
<ul>
@foreach (GridSelectedCellDescriptor cellDescriptor in SelectedCells)
{
<li>
Column <code>Field</code>: @cellDescriptor.ColumnField,
<code>EmployeeId</code>: @( ((Employee)cellDescriptor.DataItem).EmployeeId )
</li>
}
</ul>
@code {
private List<Employee> GridData { get; set; } = new();
private IEnumerable<GridSelectedCellDescriptor> SelectedCells { get; set; } = Enumerable.Empty<GridSelectedCellDescriptor>();
protected override void OnInitialized()
{
for (int i = 1; i <= 15; i++)
{
GridData.Add(new Employee()
{
EmployeeId = i,
Name = $"Employee {i}",
Team = $"Team {i % 3 + 1}"
});
}
SelectedCells = new List<GridSelectedCellDescriptor>() {
new GridSelectedCellDescriptor()
{
DataItem = GridData.ElementAt(2),
ColumnField = nameof(Employee.Name)
}
};
}
public class Employee
{
public int EmployeeId { get; set; }
public string Name { get; set; } = string.Empty;
public string Team { get; set; } = string.Empty;
}
}
SelectedCellsChanged Event
You can respond to user selection actions through the SelectedCellsChanged
event. The event handler receives a collection of type IEnumerable<GridSelectedCellDescriptor>
. The collection may have multiple, single, or no objects in it, depending on the SelectionMode
and the last user selection.
@* Select cells and handle the SelectedCellsChanged event *@
<TelerikGrid Data="@GridData"
SelectionMode="@GridSelectionMode.Multiple"
SelectedCells="@SelectedCells"
SelectedCellsChanged="@( (IEnumerable<GridSelectedCellDescriptor> newSelected) => OnCellSelect(newSelected) )"
Pageable="true">
<GridSettings>
<GridSelectionSettings SelectionType="@GridSelectionType.Cell" DragToSelect="true" />
</GridSettings>
<GridColumns>
<GridColumn Field="@nameof(Employee.Name)" />
<GridColumn Field="@nameof(Employee.Team)" />
</GridColumns>
</TelerikGrid>
<p><code>SelectedItemsChanged</code> fired at: @SelectedCellsChangedLog</p>
<h3>Selected Cells:</h3>
<ul>
@foreach (GridSelectedCellDescriptor cellDescriptor in SelectedCells)
{
<li>
Column <code>Field</code>: @cellDescriptor.ColumnField,
<code>EmployeeId</code>: @( ((Employee)cellDescriptor.DataItem).EmployeeId )
</li>
}
</ul>
@code {
private List<Employee> GridData { get; set; } = new();
private IEnumerable<GridSelectedCellDescriptor> SelectedCells { get; set; } = Enumerable.Empty<GridSelectedCellDescriptor>();
private string SelectedCellsChangedLog { get; set; } = string.Empty;
protected void OnCellSelect(IEnumerable<GridSelectedCellDescriptor> cellDescriptors)
{
// Update the SelectedCells collection manually.
// When using two-way binding, this happens automatically.
SelectedCells = cellDescriptors;
SelectedCellsChangedLog = DateTime.Now.ToLongTimeString();
}
protected override void OnInitialized()
{
for (int i = 1; i <= 15; i++)
{
GridData.Add(new Employee()
{
EmployeeId = i,
Name = $"Employee {i}",
Team = $"Team {i % 3 + 1}"
});
}
SelectedCells = new List<GridSelectedCellDescriptor>() {
new GridSelectedCellDescriptor()
{
DataItem = GridData.ElementAt(2),
ColumnField = nameof(Employee.Name)
}
};
}
public class Employee
{
public int EmployeeId { get; set; }
public string Name { get; set; } = string.Empty;
public string Team { get; set; } = string.Empty;
}
}
SelectedCellsChanged and Asynchronous Operations
The SelectedCellsChanged
event handler cannot be awaited. To execute asynchronous operations when the user selects rows, use the OnRowClick
or OnRowDoubleClick
event instead.
GridSelectedCellDescriptor
The GridSelectedCellDescriptor
type exposes the following properties:
Property Name | Type | Description |
---|---|---|
ColumnField |
string |
The value of the Grid column Field parameter, if set. |
ColumnId |
string |
The value of the Grid column Id parameter, if set. |
DataItem |
object |
The Grid data item instance. Cast it to the actual Grid model type before use. |
Selection When Data Changes
When the Grid Data
collection changes, the SelectedCells
collection has the following behavior:
- When the user updates a selected cell and the item instance is replaced, you have to also replace the
DataItem
object in theSelectedCells
collection. Do that in the GridOnUpdate
event. - When the user deletes a row with selected cells, update the
SelectedCells
collection in the the GridOnDelete
event handler. - To select cells from a new item in the Grid you can use the
OnCreate
event to update theSelectedCells
collection.
Equals Comparison
The items in SelectedCells
are compared against the items in the Grid data in order to determine which cells will be highlighted. The default framework behavior is to compare objects by reference. The data item references may not match when:
- The Grid is databound through its
OnRead
event and each data request returns different data item instances. - The
SelectedCells
are obtained from a different data source than the all Grid items, for example, from a separate service.
In such cases, the selected cells may not appear as expected. You have to override the Equals
method of the Grid model class so that the items are compared by a unique identifier rather than by reference. When you override Equals
, it is also recommended to override the GetHashCode
method.
Cell Selection and Other Grid Features
The selection feature behavior may vary when the Grid configuration combines cell selection and other Grid features, such as editing, virtualization, paging, templates. In such cases you need to consider certain limitation or include some modications.
Selection and Editing Modes
When you want to edit a Grid item, the cell selection has the following behavior:
- Cell selection is not supported with
Incell
edit mode due to the overlapping pointer events that trigger selection and editing. -
Inline
edit mode andPopup
edit mode integrate with cell selection without limitations.
Selection and Virtual Scrolling
When the Grid has virtual scrolling, the component is able to select a range of cells with Shift only if all rows in that range are currently rendered. Consider the following scenario:
- Select a cell.
- Scroll down, so that virtualization kicks in and the rendered rows are no longer the same.
- Select another cell with Shift.
In this case, the range selection will start from the first row that is currently rendered. Compare with Selection and paging below.
Selection and Paging
The SelectedCells
collection persists across paging.
Selection and Templates
When using Grid templates with cell selection:
- If you are using a Grid column template and you have a clickable element in the template, wrap this element in a container with a
@onclick:stopPropagation
directive. You can check the knowledge base article on how to prevent row selection when the user clicks another component in the Grid column template. It applies for both row and cell selection. - If you are using a row template the Grid does not support cell selection. The row template removes the built-in cell instances and the HTML markup may not even include the expected number of cells.