Blazor Estilo condicional de grade hierárquica
O recurso Ignite UI for Blazor Estilo condicional em Blazor grade hierárquica permite o estilo personalizado em um nível de linha ou célula. A IgbHierarchicalGrid
funcionalidade Estilo condicional é usada para enfatizar ou realçar visualmente os dados que atendem a determinados critérios, tornando mais fácil para os usuários identificar informações ou tendências importantes na grade.
Hierarchical Grid Conditional Row Styling
O IgbHierarchicalGrid
componente no Ignite UI for Blazor fornece duas maneiras de estilizar condicionalmente linhas com base em regras personalizadas.
- Ao definir
RowClasses
aIgbHierarchicalGrid
entrada no componente; - Ao definir
RowStyles
aIgbHierarchicalGrid
entrada no componente;
Mais adiante neste tópico, abordaremos os dois com mais detalhes.
Using Row Classes
Você pode estilizar condicionalmente as IgbHierarchicalGrid
linhas definindo a RowClasses
entrada e definir regras personalizadas.
<IgbHierarchicalGrid AutoGenerate="true" Id="grid" Data="CustomersData" Name="grid" RowClassesScript="RowClassesHandler" @ref="grid">
</IgbHierarchicalGrid>
A RowClasses
entrada aceita um literal de objeto, contendo pares chave-valor, em que a chave é o nome da classe CSS, enquanto o valor é uma função de retorno de chamada que retorna um valor booleano ou booleano.
igRegisterScript("RowClassesHandler", () => {
return {
activeRow: (row) => row.index === 0
};
}, true);
.activeRow {
border: 2px solid #fc81b8;
border-left: 3px solid #e41c77;
}
Demo
Using Row Styles
O IgbHierarchicalGrid
controle expõe a propriedade que permite o RowStyles
estilo condicional das linhas de dados. Semelhante a RowClasses
ele, aceita um literal de objeto em que as chaves são propriedades de estilo e os valores são expressões para avaliação. Além disso, você pode aplicar um estilo regular (sem quaisquer condições).
The callback signature for both
RowStyles
andRowClasses
is:
(row) => boolean
Vamos definir nossos estilos:
igRegisterScript("WebGridRowStylesHandler", () => {
return {
background:(row: RowType) => row.data['HasGrammyAward'] ? '#eeddd3' : '#f0efeb',
'border-left': (row: RowType) => row.data['HasGrammyAward'] ? '2px solid #dda15e' : null
};
}, true);
igRegisterScript("WebGridChildRowStylesHandler", () => {
return {
'border-left': (row: RowType) => row.data['BillboardReview'] > 70 ? '3.5px solid #dda15e' : null
};
}, true);
<IgbHierarchicalGrid AutoGenerate="true" RowStylesScript="WebGridRowStylesHandler"
Height="580px" Width="100%">
<IgbRowIsland ChildDataKey="Albums" AutoGenerate="true" RowStylesScript="WebGridChildRowStylesHandler">
</IgbRowIsland>
</IgbHierarchicalGrid>
Demo
Hierarchical Grid Conditional Cell Styling
Visão geral
O IgbHierarchicalGrid
componente em Ignite UI for Blazor fornece duas maneiras de estilizar condicionalmente de células com base em regras personalizadas.
- Definindo a
IgbColumn
entradaCellClasses
para um literal de objeto contendo pares de valores-chave. A chave é o nome da classe CSS, enquanto o valor é uma função de retorno de chamada que retorna um valor booleano ou booleano. O resultado é um estilo de material conveniente da célula.
Using Cell Classes
Você pode estilizar condicionalmente as IgbHierarchicalGrid
células definindo o IgbColumn
CellClasses
insira e defina regras personalizadas.
<IgbColumn Field="BeatsPerMinute" CellClassesScript="GrammyNominationsCellClassesHandler">
A CellClasses
entrada aceita um literal de objeto, contendo pares chave-valor, em que a chave é o nome da classe CSS, enquanto o valor é uma função de retorno de chamada que retorna um valor booleano ou booleano.
igRegisterScript("GrammyNominationsCellClassesHandler", () => {
return {
downFont: (rowData, columnKey) => rowData[columnKey] < 5,
upFont: (rowData, columnKey) => rowData[columnKey] >= 6
};
}, true);
.upFont {
color: green !important;
}
.downFont {
color: red !important;
}
Demo
- Usando a
IgbColumn
entradaCellStyles
que aceita um literal de objeto em que as chaves são propriedades de estilo e os valores são expressões para avaliação.
A assinatura de retorno de chamada para ambos
cellStyles
ecellClasses
agora é alterada para:
(rowData, columnKey, cellValue, rowIndex) => boolean
Using Cell Styles
As colunas expõem a propriedade que permite o CellStyles
estilo condicional das células da coluna. Semelhante a CellClasses
ele, aceita um literal de objeto em que as chaves são propriedades de estilo e os valores são expressões para avaliação. Além disso, você pode aplicar o estilo regular com facilidade (sem quaisquer condições).
Vamos definir nossos estilos:
igRegisterScript("CellStylesHandler", () => {
return {
background: (rowData, columnKey, cellValue, rowIndex) => rowIndex % 2 === 0 ? "#EFF4FD" : null,
color: (rowData, columnKey, cellValue, rowIndex) => {
if (columnKey === "Debut") {
return cellValue > 2000 ? "#28a745" : "#dc3545";
}
return undefined;
}
};
}, true);
<IgbColumn CellStylesScript="CellStylesHandler">
</IgbColumn>
Demo
Known issues and limitations
- Se houver células associadas à mesma condição (de colunas diferentes) e uma célula for atualizada, as outras células não serão atualizadas com base no novo valor, se a condição for atendida.
API References
Additional Resources
Nossa comunidade é ativa e sempre acolhedora para novas ideias.