Datalist ItemDataBound en ASP.NET

Pour personnaliser les éléments au moment de l’exécution à l’aide de l’événement ItemDataBound
1. Créez un gestionnaire d’événements pour l’événement ItemDataBound du contrôle DataList. Pour plus d’informations, consultez Création de gestionnaires d’événements dans les pages Web Forms.
2. Dans le gestionnaire d’événements, utilisez la propriété e.Item.DataItem pour tester les données qui seront liées au contrôle et effectuez une comparaison sur la base de ces données.
L’exemple suivant montre comment effectuer un test conditionnel fondé sur les données. L’exemple extrait le troisième champ Quantity de DataItem. Si la quantité est inférieure à 10, l’élément du contrôle DataList est affiché en rouge.
// C#
private void DataList1_ItemDataBound(object sender,
System.Web.UI.WebControls.DataListItemEventArgs e)
{
DataRowView drv = (DataRowView)(e.Item.DataItem);
int quantity = int.Parse(drv.Row["Quantity"].ToString());
if (quantity < 10) { e.Item.BackColor = Color.Red; }

}
Lien vers aide microsoft

Datalist Généralité et Evénements en ASP.NET

Événements
Le contrôle DataList prend en charge plusieurs événements. L’un d’eux, l’événement ItemCreated, vous offre la possibilité de personnaliser le processus de création d’éléments au moment de l’exécution. L’événement ItemDataBound vous offre aussi le moyen de personnaliser le contrôle DataList mais après que les données sont accessibles pour consultation. Par exemple, si vous utilisez le contrôle DataList pour afficher une liste de tâches, vous pouvez afficher les éléments en retard en rouge, les tâches terminées en noir et les autres tâches en vert. Vous pouvez utiliser l’un ou l’autre de ces événements pour substituer la mise en forme définie dans le modèle.
Les autres événements sont déclenchés en réponse à des clics de bouton dans les éléments de la liste. Ils sont conçus afin de vous aider à répondre aux fonctionnalités les plus utilisées du contrôle DataList. Quatre événements de ce type sont pris en charge :
* EditCommand
* DeleteCommand
* UpdateCommand
* CancelCommand
Lorsqu’un utilisateur clique sur un bouton dans un élément, l’événement remonte jusqu’au conteneur du bouton, en l’occurrence le contrôle DataList. L’événement précis déclenché par le bouton dépend de la propriété CommandName du bouton sur lequel un utilisateur a cliqué. Par exemple, si la propriété CommandName d’un bouton est edit, le bouton déclenche un événement EditCommand. Si la propriété CommandName est delete, le bouton déclenche un événement DeleteCommand, etc.
Le contrôle DataList prend également en charge l’événement ItemCommand, déclenché lorsqu’un utilisateur clique sur un bouton qui ne possède pas de commande prédéfinie telle que edit ou delete. Vous pouvez utiliser cet événement pour disposer de fonctionnalités personnalisées, en configurant la valeur requise pour la propriété CommandName du bouton puis en le testant dans le gestionnaire d’événements ItemCommand. (Vous pouvez, par exemple, recourir à cette approche lors de la sélection d’un élément, comme décrit dans Configuration du contrôle serveur Web DataList afin de permettre aux utilisateurs d’y sélectionner des éléments.)
Pour obtenir une liste complète des événements pris en charge par le contrôle DataList, consultez DataList, événements. Pour plus d’informations sur les événements associés aux Web Forms, consultez Modèle d’événements du contrôle serveur ASP.NET.
Édition et sélection d’éléments
Vous pouvez offrir aux utilisateurs la possibilité de modifier des éléments individuels du contrôle. La stratégie classique consiste à créer un modèle EditItemTemplate qui fournit la disposition et les contrôles appropriés pour le mode édition. Vous devez également fournir aux utilisateurs un moyen d’indiquer qu’ils souhaitent modifier l’élément. La méthode la plus courante consiste à inclure un bouton dans le modèle ItemTemplate (et AlternatingItemTemplate, si vous l’utilisez) puis à attribuer à la propriété CommandName du bouton, la valeur edit. Dès lors, lors d’un clic sur le bouton, le contrôle DataList déclenche automatiquement l’événement EditCommand. Dans le gestionnaire d’événements de cet événement, vous activez le mode édition pour l’élément, ce qui affiche le modèle EditItemTemplate.
EditItemTemplate inclut généralement des boutons qui permettent à l’utilisateur d’enregistrer les modifications ou de les rejeter (par exemple des boutons Mettre à jour et Annuler). Ces boutons fonctionnent de la même façon que le bouton Modifier : ils envoient un message de commande prédéfini (update ou cancel) au contrôle DataList, lequel déclenche un événement UpdateCommand ou CancelCommand auquel vous pouvez répondre de la façon requise. Dans le cas d’une application de suivi des clients, les modèles peuvent ressembler à ceux illustrés ci-dessous.
Le processus de sélection d’un élément est similaire et recourt à l’événement SelectedIndexChanged. Vous ajoutez un bouton au modèle ItemTemplate et vous attribuez la valeur select à sa propriété CommandName. Vous écrivez ensuite un gestionnaire d’événements pour l’événement SelectedIndexChanged. L’événement SelectedIndexChanged est déclenché lorsque l’utilisateur clique sur le bouton Sélectionner. Pour plus d’informations, consultez Configuration du contrôle serveur Web DataList afin de permettre aux utilisateurs d’y sélectionner des éléments.

Source Microsoft

Pour en savoir plus :
Aide Microsoft