ASP.NET GridView RowDataBound event
Gestire l'evento RowDataBound di una GridView può essere molto comodo per svariati motivi, come ad esempio cambiare il colore di sfondo di una particolare cella, calcolare dei totali/subtotali con delle politiche personalizzate, ecc.
L'evento scatta al Binding della singola riga, e avviene prima del disegno della riga stessa.
Il modo corretto per recuperare i dati della riga sulla quale cambia a seconda del provider dei dati della griglia
- Caso in cui la griglia è in binding con un DataSource di tipo Object
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
//Checking the RowType of the Row
if(e.Row.RowType==DataControlRowType.DataRow)
{
MYTYPE myRow = (MYTYPE)e.Row.DataItem;
MYTOTAL += myRow.VALUE;
}
}
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
//Checking the RowType of the Row
if(e.Row.RowType==DataControlRowType.DataRow)
{
if(Convert.ToInt32(e.Row.Cells[3].Text)<10000)
{
e.Row.BackColor = Color.Cyan;
}
}
}
Nel primo caso abbiamo accesso diretto alle proprietà dell'oggetto, previo opportuno cast con e.Row.DataItem, mentre nel secondo caso abbiamo accesso ai valori presenti nelle varie colonne della tabella con e.Row.Cells[3].Text, pertanto dobbiamo ricordarci le posizioni dei campi nella griglia.
Ecco un altro caso che dovrebbe farci sempre scegliere la modalità di lavoro ad "oggetti"!