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

 Delphi Discussion :

selection dans un TComboBox


Sujet :

Delphi

  1. #1
    Membre du Club
    Inscrit en
    Août 2002
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Août 2002
    Messages : 108
    Points : 46
    Points
    46
    Par défaut selection dans un TComboBox
    Bonjour ,
    je reviens encore

    jai une table: type de versement avec 02 champs :CODE_TYPE_VERST type integer; et LIBELLE_TYPE type char; - j'ai place un TComboBox sur ma form que j'arrive à remplire dans son évenement ComboBox3DropDown avec le code suivant :
    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
    procedure TF_CorrectionVersement.ComboBox3DropDown(Sender: TObject);
     var
    i : Integer;
    texte: string;
    begin
    ComboBox3.Items.Clear;
    dm.ADOQuery55.close;
    dm.ADOQuery55.open;
        if  DM.combo3.recordcount<>0 then
          for i := 1 to DM.combo3.recordcount do  {là je remplit ma combobox}
            begin
             texte:= DM.combo3.fieldbyname('LIBELLE_TYPE').asstring;
             ComboBox3.items.AddObject(texte, TObject(i));
             DM.combo3.next;
              end;
    end;
    Le Problème Comment choisir l'index d'un enregistrement donné de la table

    par exemple si je dois choisir "virement qui est à la position N°1" ou "espèce qui est position n° 3" etc... j'ai fait ceci dans le ComboBox3Change :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    procedure TF_CorrectionVersement.ComboBox3Change(Sender: TObject);
     begin
    with ComboBox3 do
    if Items.IndexOf('ComboBox3.text') = ItemIndex then
    begin
    ItemIndex := Items.IndexOf('ComboBox3.text');
    //showmessage('code vers '+)
    end;
    end;
    je n'arrive pas à faire la modif dans la table versement

    merci d'avance pour l'éclairage

  2. #2
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 459
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 459
    Points : 24 873
    Points
    24 873
    Par défaut
    Pourquoi ne pas utiliser un TDBLookupComboBox ?

    Je n'ai pas bien compris l'intérêt du code de ton ComboBox3Change, je dirais que cela ne sert à rien (SI A = B ALORS A recoit B, inutile), voir indique que tu n'as pas compris grand chose ( c'est exprès que ComboBox3.Text soit une chaine ???)

    ADOQuery55, ComboBox3, combo3, ça c'est un nommage pérenne et aide à la compréhension de tous !

    supposons que ADOQuery55 est la table versement, et que l'on puisse la modifier (voir CanModify)

    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
    procedure TF_CorrectionVersement.ComboBox3DropDown(Sender: TObject);
     var
    i, k : Integer;
    texte: string;
    begin
    ComboBox3.Items.Clear;
    ComboBox3.ItemIndex = -1;
    dm.ADOQuery55.close;
    dm.ADOQuery55.open;
        if  DM.combo3.recordcount<>0 then
          for i := 1 to DM.combo3.recordcount do  {là je remplit ma combobox}
            begin
             texte:= DM.combo3.fieldbyname('LIBELLE_TYPE').asstring;
             k := ComboBox3.items.AddObject(texte, TObject(i));
             if DM.ADOQuery55.FieldByName('LeChampCode').AsInteger = DM.combo3.FieldByName('CODE_TYPE_VERST').AsInteger then
               ComboBox3.ItemIndex = k;
     
             DM.combo3.next;
              end;
    end;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    procedure TF_CorrectionVersement.ComboBox3Change(Sender: TObject);
    begin
      if (ComboBox3.ItemIndex  >= 0) and DM.combo3.Locate('LIBELLE_TYPE', ComboBox3.text, []) then
      begin
        DM.ADOQuery55.Edit();
        DM.ADOQuery55.FieldByName('LeChampCode').AsInteger =  DM.combo3.FieldByName('CODE_TYPE_VERST').AsInteger 
        DM.ADOQuery55.Post();
      end;
    end;
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

Discussions similaires

  1. Multi-selection dans une ComboBox ?
    Par Moloko dans le forum MFC
    Réponses: 5
    Dernier message: 07/07/2021, 17h26
  2. Réponses: 8
    Dernier message: 05/05/2004, 16h28
  3. select dans un trigger sous Postgresql
    Par kastor_grog dans le forum Requêtes
    Réponses: 1
    Dernier message: 03/09/2003, 17h00
  4. [Sybase] Select dans une select loop en C
    Par Claudio dans le forum Sybase
    Réponses: 2
    Dernier message: 29/04/2003, 18h06
  5. faire un selection dans une image aves les APIs
    Par merahyazid dans le forum C++Builder
    Réponses: 3
    Dernier message: 30/04/2002, 10h44

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