IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

Probleme avec le Combobox [Débutant]


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif

    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 27
    Billets dans le blog
    1
    Par défaut Probleme avec le Combobox
    Hello! Je suis un débutant en Programmation. Au fait j'ai un problème avec le comboBox, j'ai reçu à afficher les noms des produit, mais je souhaite enregistrer Uniquement l'Id dans ma Base de Donnees lorsque se fait selectionné un Nom de produit quand je clic sur buton Enregistrer.

  2. #2
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2018
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2018
    Messages : 14
    Par défaut
    Est ce que tu as définis ton produit comme une classe ? Comment as tu remplis ta combobox?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public classe Produit 
    {
    public int id {get; set; }
    public string nom {get; set; }
    }
    comboBox1.ItemsSource = GetAllProduit();
    comboBox1.Items.Refresh();
    Et dans ton XAML au niveau de ta comboBox:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <ComboBox Name = "comboBox1" Binding = "{Binding id}" />

  3. #3
    Membre expérimenté
    Homme Profil pro
    Administrateur Systèmes, Clouds et Réseaux /CAO/DAO/Ingénierie Electrotechnique
    Inscrit en
    Décembre 2014
    Messages
    457
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Administrateur Systèmes, Clouds et Réseaux /CAO/DAO/Ingénierie Electrotechnique

    Informations forums :
    Inscription : Décembre 2014
    Messages : 457
    Par défaut
    pardon mais peut être que je me trompe mais il me semble que si l'on désire avoir l'affichage d'un nom d'un produit mais parcontre le sélectionner par l'id, ça va donner plutot (en respectant dans la foulée le split design/code qui vient avec le wpf)
    un accesseur en public
    ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public ObservableCollection<Produit> MesProduits {get;set;}
    Cet accesseur au chargement sera initialisé avec les produits,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    public MaFenêtre()
    {
                InitializeComponent();
        DataContext = this;
        MesProduits = GetAllProduit();
    }
    et dans le xaml
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <ComboBox ItemsSource="{Binding MesProduits }" DisplayMemberPath="nom" SelectedValuePath="id" [...] />
    Notes:
    - id et nom devraient prendre une majuscule, il me semble, au niveau de la classe pour respecter la convention.
    - Observable Collection est utile si l'on compte pouvoir agir dynamiquement sur la combobox, sans quoi une simple List suffit.
    - [...] symbolise tout ce qu'on peut rajouter dans la balise avant de fermer.

  4. #4
    Membre actif

    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 27
    Billets dans le blog
    1
    Par défaut Remplissage du Combo Box
    Merci pour votre aide. Voici comment j'ai remplir mon ComboBox:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Configuration;
    using System.Data;
    using System.Data.OleDb;
    using System.Drawing;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows.Forms;
     
    namespace PERSONNES
    {
        public partial class Gerer : Form
        {
            OleDbConnection con = new OleDbConnection();
            public Gerer()
            {
                InitializeComponent();
                FillNoms();
                FillAct();
            }
     
            void FillEqui()
            {
                string ConnectionString = " Provider = Microsoft.ACE.OLEDB.12.0; Data Source = F:\\Stage_ap\\BD\\MontHoreb.accdb";
                con.ConnectionString = ConnectionString;
                con.Open();
                OleDbDataAdapter adapter = new OleDbDataAdapter("Select NomsPrdt from PRODUIT", con);
                DataTable dt = new DataTable();
                adapter.Fill(dt);
                cmbCodeEquiG.DataSource = dt;
                cmbCodeEquiG.DisplayMember = "Select NomsPrdt ";
                con.Close();
     
            }

  5. #5
    Membre Expert
    Homme Profil pro
    edi
    Inscrit en
    Juin 2007
    Messages
    941
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : edi

    Informations forums :
    Inscription : Juin 2007
    Messages : 941
    Par défaut
    C'est du WinForms et non du WPF, donc les morceaux de code qui précèdent ne te seront pour l'essentiel pas très utiles. Néanmoins l'idée de base d'avoir une classe produit avec un id et un nom reste valide. Il faut que ta requête récupère l'id du produit en plus du nom, puis tu crées un tableau de produits à partir de ces données (int.Parse permet d'obtenir un entier à partir d'une chaine). La propriété DisplayMember de la ComboBox te permet d'afficher le nom du produit (en profitant de pour sécuriser le terme à employer). La propriété SelectedItem te donnera l'objet actuellement sélectionné (en faisant un cast) et dont tu pourras rcupérer l'id.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    public class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }
     
    public partial class Gerer : Form
        {
            OleDbConnection con = new OleDbConnection();
            public Gerer()
            {
                InitializeComponent();
                FillNoms();
                FillAct();
            }
     
            void FillEqui()
            {
                string ConnectionString = " Provider = Microsoft.ACE.OLEDB.12.0; Data Source = F:\\Stage_ap\\BD\\MontHoreb.accdb";
                con.ConnectionString = ConnectionString;
                con.Open();
                OleDbDataAdapter adapter = new OleDbDataAdapter("Select Idprdt, NomsPrdt from PRODUIT", con);
                DataTable dt = new DataTable();
                adapter.Fill(dt);
                var products = new List<Product>();
                foreach(var row in dt.Rows) { products.Add(new Product { Id = int.Parse((string)row["IdPdrt"]), Name = (string)row["NomsPdrt"] }); }
                cmbCodeEquiG.DataSource = products;
                cmbCodeEquiG.DisplayMember = "NomsPrdt ";
                con.Close();
     
            }
    J'ai écrit ce code vite fait sans tester, donc je ne garantie pas qu'il n'y a pas d'erreur mais on devrait pas être loin d'un code fonctionnel. Ensuite il faudra qu'on parle des architectures en couches et de la gestion des erreurs.

  6. #6
    Membre actif

    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 27
    Billets dans le blog
    1
    Par défaut
    Hello j'ai teste mais ça marche pas

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Problemes avec le ComboBox C#
    Par mourbare dans le forum Windows Forms
    Réponses: 5
    Dernier message: 02/09/2008, 14h22
  2. probleme avec une combobox
    Par juliusezar dans le forum C#
    Réponses: 8
    Dernier message: 03/08/2007, 15h47
  3. [VB.NET] probleme avec une combobox en ado.net
    Par scorpion.os dans le forum Windows Forms
    Réponses: 7
    Dernier message: 11/05/2006, 14h16
  4. probleme avec une combobox
    Par el_quincho dans le forum IHM
    Réponses: 1
    Dernier message: 09/02/2006, 16h14
  5. [FLASH MX2004] Probleme avec un combobox
    Par pierrot10 dans le forum Flash
    Réponses: 3
    Dernier message: 28/10/2005, 17h35

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo