Cookie Consent by Free Privacy Policy Generator Polipone
<febbraio 2026>
lunmarmergiovensabdom
2627282930311
2345678
9101112131415
16171819202122
2324252627281
2345678
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;
        }   
    }

  • Altri casi

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"!
Tutor On-Line
Ciao, sono il tuo Tutor on-line. Come posso aiutarti? 01:07

Notifiche