Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Thomas Lebrun

Tout sur WPF, LINQ, C# et .NET en général !

Actualités

[WPF] Que faire lorsque vous n'arrivez pas à supprimer un élément d'une ComboBox/ListBox liée à une table LINQ To SQL ?

Imaginez le scénario suivant, très fréquent avec WPF (entre autre): vous disposez d'une ComboBox/ListBox et la source de données de ce contrôle est une "table" générée par LINQ To SQL.

Un bouton de votre interface vous permet de supprimer un élément de votre ListBox/ComboBox et d'envoyer les modifications sur le serveur (via un appel à SubmitChanges)

Seul petit problème, rencontré par beaucoup de monde: l'élément est bien supprimé en base mais l'interface utilisateur ne change pas (l'élément reste dans la ListBox/ComboBox).

Le problème vient du fait que les classes générées par LINQ To SQL n'implémente pas l'interface INotifyCollectionChanged, qui permet de déclencher un évènement notifiant l'interface utilisateur qu'un élément a été ajouté/supprimé.

Afin de corriger le problème dont nous venons de parler, il convient donc d'implémenter cette interface sur les classes générées (n'oubliez pas que ce sont des classes partielles) ou bien de passer par la classe ObservableCollection<T>, qui implémente déjà cette interface.

Ainsi, ce code, non fonctionnel:

PhotosDataContext dc = new PhotosDataContext();

this.lb.DataContext = dc.Photos.ToList();

Devient:

PhotosDataContext dc = new PhotosDataContext();

 

this.lb.DataContext = new ObservableCollection<Photo>(dc.Photos.ToList());

Et, lors de l'appel à la méthode de suppression, il "suffit" d'accéder à la propriété DataContext, de la convertir en ObservableCollection (car il s'agit d'un object) et de supprimer l'élément sélectionné dans le contrôle:

private void btnDelete_Click(object sender, RoutedEventArgs e)

{

    if (this.lb.SelectedItem != null)

    {

        dc.Photos.DeleteOnSubmit((Photo)this.lb.SelectedItem);

 

        ((ObservableCollection<Photo>)this.lb.DataContext).Remove((Photo)this.lb.SelectedItem);

 

        dc.SubmitChanges();

        }

    }

}

Attention, pour que ce code fonctionne, n'oubliez pas de mettre à True la propriété IsSynchronizedWithCurrentItem, sinon vous risquez d'avoir une NullReferenceException sur la propriété SelectedItem:

IsSynchronizedWithCurrentItem = "True"

 

A+

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: mercredi 16 juillet 2008 09:15 par Thomas LEBRUN
Classé sous : ,

Commentaires

clark a dit :

Bonjour et Merci

Je séchais justement sur un problème similaire!

# juillet 16, 2008 15:51
Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- Sortie de Silverlight 2 et de Flash player 10 par Nix's Blog le il y a 15 heures et 36 minutes

- Installation Silverlight RC0 et final ... par #Rui le il y a 16 heures et 28 minutes

- TCB : Que faire en salle blanche ? par The Mit's Blog le il y a 16 heures et 57 minutes

- Debug : Make Object ID - Comment connaitre l'état d'une variable lorsque celle-ci n'est pas accessible dans le scope courant par Atteint de JavaScriptite Aiguë [Cyril Durand] le 10-14-2008, 21:42

- IIS7 : Configuration des handlers pour l'upload de fichier - interdire certains fichiers de s'exécuter | accéder à des fichiers .cs, .aspx par Atteint de JavaScriptite Aiguë [Cyril Durand] le 10-14-2008, 19:49

- Microsoft annonce le nom commercial de Windows 7 par Code is poetry le 10-14-2008, 12:07

- [Silverlight] Téléchargez la version finale (et les outils associés) dès maintenant ! par Thomas Lebrun le 10-14-2008, 10:37

- Vilain bug avec IQueryable et la syntaxe yield : System.BadImageFormatException "An attempt was made to load a program with an incorrect format. (Exce... par Matthieu MEZIL le 10-14-2008, 07:48

- SQL Server 2008 : Un livre en cours de préparation ! par SQL Server vu par Christian Robert le 10-13-2008, 22:56

- IIS7 : à quel pool d'application correspond le processus w3wp.exe par Atteint de JavaScriptite Aiguë [Cyril Durand] le 10-13-2008, 21:59