Web Components Selección de filas de cuadrícula de árbol
La función Ignite UI for Web Components selección de filas de Web Components cuadrícula de árbol permite a los usuarios seleccionar, resaltar o anular la selección interactiva de una o varias filas de datos. Hay varios modos de selección disponibles en: IgcTreeGridComponent
- Ninguna selección
- Selección múltiple
- Selección única
Web Components Row Selection Example
En el ejemplo siguiente se muestran los cuatro tipos de IgcTreeGridComponent
Es decir, que Selección de filas comportamiento. Utilice los botones de abajo para activar cada uno de los modos de selección disponibles. Se proporcionará una breve descripción de cada interacción de botón a través de un cuadro de mensaje de snackbar. Utilice el botón de cambio para esconder o mostrar la casilla de verificación Selector de filas.
Setup
Para configurar la selección de filas en el IgcTreeGridComponent
, solo necesita establecer la rowSelection
propiedad. Esta propiedad acepta la GridSelectionMode
enumeración.
GridSelectionMode
expone los siguientes modos:
- Ninguno
- Soltero
- Múltiple
- MultipleCascade
A continuación veremos cada uno de ellos con más detalle.
Ninguna selección
De forma predeterminada, la IgcTreeGridComponent
selección de filas está deshabilitada (rowSelection
es Ninguna). Por lo tanto, no puede seleccionar o anular la selección de una fila a través de la interacción con la interfaz de usuario, la única manera de completar estas acciones es usar los métodos de IgcTreeGridComponent
API proporcionados.
Selección única
La selección de una sola fila ahora se puede configurar fácilmente; lo único que debe hacer es establecer rowSelection
en la propiedad Single
. Esto le brinda la oportunidad de seleccionar sólo una fila dentro de una cuadrícula. Puede seleccionar una fila haciendo clic en una celda o presionando la tecla de espacio cuando se enfoca en una celda de la fila y, por supuesto, puede seleccionar una fila haciendo clic en el campo selector de filas. Cuando se selecciona o deselecciona una fila, se emite el evento RowSelectionChanging
.
<igc-tree-grid id="grid" row-selection="Single" auto-generate="true"
allow-filtering="true">
</igc-tree-grid>
constructor() {
const grid = document.getElementById('grid') as IgcTreeGridComponent;
grid.data = this.data;
grid.addEventListener("rowSelectionChanging", this.handleRowSelection);
}
public handleRowSelection(args: IgcRowSelectionEventArgs) {
if (args.detail.added.length && args.detail.added[0] === 3) {
args.detail.cancel = true;
}
}
Selección múltiple
Para habilitar la selección de varias filas en el IgcTreeGridComponent
simplemente establezca la rowSelection
propiedad en Multiple
. Esto habilitará un campo selector de filas en cada fila y en el IgcTreeGridComponent
encabezado. El selector de filas permite a los usuarios seleccionar varias filas, y la selección persiste a través del desplazamiento, la paginación y las operaciones de datos, como la ordenación y el filtrado. La fila también se puede seleccionar haciendo clic en una celda o presionando la tecla de espacio cuando una celda está enfocada. Si ha seleccionado una fila y hace clic en otra mientras mantiene presionada la tecla Mayús, esto seleccionará todo el rango de filas. En este modo de selección, al hacer clic en una sola fila, se anulará la selección de las filas seleccionadas anteriormente. Si hace clic mientras mantiene presionada la tecla ctrl, la fila se alternará y se conservará la selección anterior.
<igc-tree-grid id="grid" primary-key="ProductID" row-selection="Multiple"
allow-filtering="true" auto-generate="true">
</igc-tree-grid>
Cascade Selection
Para habilitar la selección de filas en cascada en el IgcTreeGridComponent
simplemente establezca la rowSelection
propiedad en MultipleCascade
. Esto habilitará un campo selector de filas en cada fila y en el IgcTreeGridComponent
encabezado. El selector de filas permite a los usuarios seleccionar varias filas que seleccionarían todos los elementos secundarios en el árbol de abajo. La selección persiste a través del desplazamiento, la paginación y las operaciones de datos, como la ordenación y el filtrado. La fila también se puede seleccionar haciendo clic en una celda o presionando la tecla de espacio cuando una celda está enfocada. Si ha seleccionado una fila y hace clic en otra mientras mantiene presionada la tecla Mayús, la selección de un registro principal seleccionará todos sus hijos, incluso si no están en el rango seleccionado. En este modo de selección, al hacer clic en una sola fila, se anulará la selección de las filas seleccionadas anteriormente. Si hace clic mientras mantiene presionada la tecla ctrl, la fila y sus elementos secundarios se alternarán y se conservará la selección anterior.
<igc-tree-grid id="grid" primaryKey="ID" foreign-key="ParentID" auto-generate="true"
row-selection="MultipleCascade" allow-filtering="true">
</igc-tree-grid>
En este modo, el estado de selección de un padre depende completamente del estado de selección de sus hijos. Cuando un padre tiene algunos hijos seleccionados y algunos no seleccionados, su casilla de verificación está en un estado indeterminado.
Notas
- La selección de filas activará el evento
RowSelectionChanging
. Este evento le brinda información sobre la nueva selección, la selección anterior y las filas que se agregaron y eliminaron de la selección anterior. Además, el evento es cancelable, por lo que esto le permite evitar la selección. - Cuando la selección de filas está habilitada, se muestran los selectores de filas, pero si no desea mostrarlos, puede configurar
hideRowSelectors
en verdadero. - Cuando cambia entre modos de selección de filas en tiempo de ejecución, esto borrará el estado de selección de filas anterior.
API usage
Select Rows Programmatically
El siguiente fragmento de código se puede utilizar para seleccionar una o varias filas simultáneamente (a través de primaryKey
). Además, el segundo parámetro de este método es una propiedad booleana mediante la cual puede elegir si la selección de fila anterior se borrará o no. La selección anterior se conserva de forma predeterminada.
<igc-tree-grid id="grid"
primary-key="ProductID"
row-selection="Multiple"
auto-generate="true">
</igc-tree-grid>
<button id='select'>Select 1,2 and 5</button>
constructor() {
document.getElementById("select").addEventListener("click", this.onClickSelect);
}
public onClickSelect() {
const grid = document.getElementById("grid") as IgcTreeGridComponent;
grid.selectRows([1,2,5], true);
}
Esto agregará las filas que corresponden a las entradas de datos con los identificadores 1, 2 y 5 a la IgcTreeGridComponent
selección.
Deselect Rows
Si necesita anular la selección de filas mediante programación, puede utilizar el método deselectRows
.
<igc-tree-grid id="grid"
primary-key="ProductID"
row-selection="Multiple"
auto-generate="true">
</igc-tree-grid>
<button id='deselect'>DeSelect</button>
constructor() {
document.getElementById("deselect").addEventListener("click", this.onClickDeselect);
}
public onClickDeselect() {
const grid = document.getElementById("grid") as IgcTreeGridComponent;
grid.deselectRows([1,2,5]);
}
Row Selection Event
Cuando hay algún cambio en la selección de filas, se emite el evento RowSelectionChanging
. RowSelectionChanging
expone los siguientes argumentos:
OldSelection
: matriz de ID de fila que contiene el estado anterior de la selección de fila.NewSelection
: matriz de ID de fila que coinciden con el nuevo estado de la selección de fila.Added
: conjunto de ID de fila que se agregan actualmente a la selección.Removed
: conjunto de ID de fila que se eliminan actualmente según el estado de selección anterior.Event
: el evento original que desencadenó el cambio de selección de fila.Cancel
: le permite evitar el cambio de selección de fila.
<igc-tree-grid id="grid">
</igc-tree-grid>
constructor() {
const grid = document.getElementById('grid') as IgcTreeGridComponent;
grid.data = this.data;
grid.addEventListener("rowSelectionChanging", this.handleRowSelectionChange);
}
public handleRowSelectionChange(args) {
args.detail.cancel = true; // this will cancel the row selection
}
Select All Rows
Otro método de API útil que IgcTreeGridComponent
proporciona es selectAllRows
. De forma predeterminada, este método seleccionará todas las filas de datos, pero si se aplica el filtrado, seleccionará solo las filas que coincidan con los criterios de filtro. Si llama al método con el parámetro false, siempre seleccionará todos los datos de la cuadrícula, SelectAllRows(false)
incluso si se aplica el filtrado.
Nota Tenga en cuenta que
selectAllRows
no seleccionará las filas que se eliminan.
Deselect All Rows
IgcTreeGridComponent
Proporciona un deselectAllRows
método que, de forma predeterminada, anulará la selección de todas las filas de datos, pero si se aplica el filtrado, anulará la selección solo de las filas que coincidan con los criterios de filtro. Si llama al método con el parámetro false, siempre borrará todo el estado de selección de filas, DeselectAllRows(false)
incluso si se aplica el filtrado.
How to get Selected Rows
Si necesita ver qué filas están seleccionadas actualmente, puede obtener sus ID de fila con el captador selectedRows
.
public getSelectedRows() {
const grid = document.getElementById('grid') as IgcTreeGridComponent;
const currentSelection = grid.selectedRows; // return array of row IDs
}
Además, asignar ID de fila a selectedRows
le permitirá cambiar el estado de selección de la cuadrícula.
public mySelectedRows = [1, 2, 3]; // an array of row IDs
constructor() {
const grid = document.getElementById('grid') as IgcTreeGridComponent;
grid.data = this.data;
grid.selectedRows = this.mySelectedRows;
}
Row Selector Templates
Puede crear selectores de encabezado y fila de plantilla en el IgcTreeGridComponent
y también acceder a sus contextos, lo que proporciona una funcionalidad útil para diferentes escenarios.
De forma predeterminada, controla IgcTreeGridComponent
todas las interacciones de selección de filas en el contenedor primario del selector de filas o en la propia fila, dejando solo la visualización de estado de la plantilla. Por lo general, la invalidación de la funcionalidad base debe realizarse mediante el evento RowSelectionChanging. En caso de que implemente una plantilla personalizada con un Click
controlador que invalide la funcionalidad base, debe detener la propagación del evento para conservar el estado de fila correcto.
Plantilla de fila
Para crear una plantilla de selector de filas personalizada, dentro de la propiedad puede usar la igc-tree-grid
rowSelectorTemplate
propiedad. Desde la plantilla se puede acceder a la variable de contexto proporcionada implícitamente, con propiedades que proporcionan información sobre el estado de la fila.
La propiedad selected
muestra si la fila actual está seleccionada o no, mientras que la propiedad index
se puede usar para acceder al índice de la fila.
public rowSelectorTemplate = (ctx: IgcRowSelectorTemplateContext) => {
if (ctx.implicit.selected) {
return html`<div style="justify-content: space-evenly;display: flex;width: 70px;">
<span> ${ctx.implicit.index}</span>
<igc-checkbox checked></igc-checkbox>
</div>`;
} else {
return html`<div style="justify-content: space-evenly;display: flex;width: 70px;">
<span> ${ctx.implicit.index}</span>
<igc-checkbox></igc-checkbox>
</div>`;
}
}
La rowID
propiedad se puede utilizar para obtener una referencia de una igc-tree-grid
fila. Esto es útil cuando se implementa un click
controlador en el elemento selector de filas.
public rowSelectorTemplate = (ctx: IgcRowSelectorTemplateContext) => {
return html`
<igc-checkbox
@click="${(event: any) => {
this.onSelectorClick(event, ctx.implicit.key);
}}"
></igc-checkbox>
`;
}
En el ejemplo anterior estamos usando un IgcCheckboxComponent
y vinculamos rowContext.selected
a su propiedad checked
. Vea esto en acción en nuestra demostración de numeración de filas.
Header Template
Para crear una plantilla de selector de encabezado personalizada, dentro de la, puede usar la IgcTreeGridComponent
headSelectorTemplate
propiedad. Desde la plantilla se puede acceder a la variable de contexto proporcionada implícitamente, con propiedades que proporcionan información sobre el estado del encabezado.
La SelectedCount
propiedad muestra cuántas filas están seleccionadas actualmente, mientras totalCount
que muestra cuántas filas hay en total IgcTreeGridComponent
.
public headSelectorTemplate = (ctx: IgcHeadSelectorTemplateContext) => {
return html` ${ctx.implicit.selectedCount} / ${ctx.implicit.totalCount} `;
};
Las propiedades SelectedCount
y TotalCount
se pueden utilizar para determinar si el selector principal debe estar marcado o indeterminado (seleccionado parcialmente).
<igc-tree-grid id="grid"
primary-key="ProductID"
row-selection="Multiple"
auto-generate="true">
</igc-tree-grid>
constructor() {
const grid = document.getElementById('grid') as IgcTreeGridComponent;
grid.data = this.data;
grid.headSelectorTemplate = this.headSelectorTemplate;
}
public headSelectorTemplate = (ctx: IgcHeadSelectorTemplateContext) => {
const implicit: any = ctx.implicit;
if (implicit.selectedCount > 0 && implicit.selectedCount === implicit.totalCount) {
return html`<igc-checkbox checked></igc-checkbox>`;
} else if (implicit.selectedCount > 0 && implicit.selectedCount !== implicit.totalCount) {
return html`<igc-checkbox indeterminate></igc-checkbox>`;
}
return html`<igc-checkbox></igc-checkbox>`;
}
Row Numbering Demo
Esta demostración muestra el uso de selectores de filas y encabezados personalizados. Este último usa index
para mostrar los números de fila y un IgcCheckboxComponent
vinculado al selected
.
Excel Style Row Selectors Demo
Esta demostración utiliza plantillas personalizadas que se parecen a los selectores de filas y encabezados similares a los de Excel.
Conditional Selection Demo
Esta demostración evita que se seleccionen algunas filas mediante el evento RowSelectionChanging
y una plantilla personalizada con la casilla de verificación deshabilitada para filas no seleccionables.
API References
IgcTreeGridComponent
TreeGridRow
Cell
Additional Resources
- Selección
- Selección de celda
- Paginación
- Filtración
- Clasificación
- resúmenes
- Columna en movimiento
- Fijación de columnas
- Cambio de tamaño de columna
- Virtualización y rendimiento
Nuestra comunidad es activa y siempre da la bienvenida a nuevas ideas.