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

VB 6 et antérieur Discussion :

'Index' d'un ComboBox.AddItem : Valeurs désordonnées.


Sujet :

VB 6 et antérieur

  1. #1
    Membre habitué
    Avatar de __fabrice
    Homme Profil pro
    Développeur Back-End
    Inscrit en
    Août 2004
    Messages
    404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Août 2004
    Messages : 404
    Points : 194
    Points
    194
    Par défaut 'Index' d'un ComboBox.AddItem : Valeurs désordonnées.
    salut à tous,

    J'ai probleme simple :

    Dans une ComboBox, je fais un AddItem et j'aimerai que le 2 eme parametre, le 'Index' ne commence pas par 0. Je voudrai lui donner les valeurs dont j'ai besoin. Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    cboAnnee.AddItem "Nouvelles rubriques", 5
    cboAnnee.AddItem "Transport", 2
    cboAnnee.AddItem "Itinéraire", 22
    Cela ne marche pas car VB veut que le 'Index' commence par 0. Comment faire pour que chaque element index de la combo est une valeur différente et pas forcement ordonnée ?

    Merci à tous,
    Fabrice

  2. #2
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Tu ajoutes
    avant de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    cboAnnee.AddItem "Nouvelles rubriques", 5 
    cboAnnee.AddItem "Transport", 2 
    cboAnnee.AddItem "Itinéraire", 22
    A+

  3. #3
    Membre habitué
    Avatar de __fabrice
    Homme Profil pro
    Développeur Back-End
    Inscrit en
    Août 2004
    Messages
    404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Août 2004
    Messages : 404
    Points : 194
    Points
    194
    Par défaut
    çà ne marche pas

    J'ai toujours la meme erreur.

    Fabrice

  4. #4
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    J'ai toujours la meme erreur
    Erreur ? Tu ne parlais pas d'erreur... Tu peux préciser ?

    A+

  5. #5
    Membre à l'essai
    Inscrit en
    Mai 2005
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 33
    Points : 21
    Points
    21
    Par défaut
    utilises plutot une autre propriete, telle que le tag, pour faire ca, car l'index est exactement a l'oppose de ce que tu veux en faire : il liste les éléments dans leur ordre !

    ainsi, je pense que tu t'embeteras moins avec le tag, qui est fait pour recevoir tout et n'importe quoi

  6. #6
    Membre habitué
    Avatar de __fabrice
    Homme Profil pro
    Développeur Back-End
    Inscrit en
    Août 2004
    Messages
    404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Août 2004
    Messages : 404
    Points : 194
    Points
    194
    Par défaut
    Il me semble que le Tag est lié au controle lui meme mais pas à chaque élément de la liste déroulante.

    Du coup, lors du AddItem, on ne peux pas assigner, avec le Tag, une valeur à chaque élément.

    Fabrice

  7. #7
    Membre habitué
    Avatar de __fabrice
    Homme Profil pro
    Développeur Back-End
    Inscrit en
    Août 2004
    Messages
    404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Août 2004
    Messages : 404
    Points : 194
    Points
    194
    Par défaut
    Oui, l'erreur c'est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Argument ou appel de procédure incorrect
    Fabrice

  8. #8
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Ok, j'ai vu,

    Pour un combo, la syntaxe est (extrait de l'aide)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
        For i = 0 To 5
            MyArray(i, 0) = i
            MyArray(i, 1) = Rnd
            MyArray(i, 2) = Rnd
        Next i
     
        'Chargez le contrôle ComboBox1
        ListBox1.List() = MyArray
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ListBox1.AddItem "Ligne 2, col. 1"
    ListBox1.List(1, 1) = "Ligne 2, col. 2"
    ListBox1.List(1, 2) = "Ligne 2, col. 3"
    Dans lesquels le 2 de List(1, 2) désigne la colonne

    ou, si tu préfères un exemple concret :

    NoCol = 1 'N° colonne des noms
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    For i = 1 To DernièreLigne - 1 '(-1) Dernière ligne vide
        MaForm.ComboAideLoyers.AddItem Cells(i + 1, NoCol).Value  
        '(+1 pour passer la ligne de titre dans la feuille de calcul)
    Next i
     
    'Ensuite, je remplis les colonnes suivante
         For NoCol = 2 To NbreColonnes   'Dans cet exemple, les noms se trouvent sur la colonne 1, donc, je lis les suivantes
              For NoLigne = 2 To DernièreLigne - 1
                    MaForm.ComboAideLoyers.List(NoLigne - 1, NoCol) = Cells(NoLigne, NoCol).Value
              Next NoLigne
         Next NoCol
    A+



    A

  9. #9
    Membre habitué
    Avatar de __fabrice
    Homme Profil pro
    Développeur Back-End
    Inscrit en
    Août 2004
    Messages
    404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Août 2004
    Messages : 404
    Points : 194
    Points
    194
    Par défaut
    Je comprends pas tout .. le Cells c'est pas du VB, mais du VBA.

    Cela ne marche pas trop non plus avec mon exemple simple.

    Fabrice

  10. #10
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Ça ne marche pas non plus avec le code de l'exemple de l'aide ?

    A+

  11. #11
    Membre habitué
    Avatar de __fabrice
    Homme Profil pro
    Développeur Back-End
    Inscrit en
    Août 2004
    Messages
    404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Août 2004
    Messages : 404
    Points : 194
    Points
    194
    Par défaut
    non

  12. #12
    Xo
    Xo est déconnecté
    Expert confirmé
    Avatar de Xo
    Inscrit en
    Janvier 2005
    Messages
    2 701
    Détails du profil
    Informations personnelles :
    Âge : 50

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 701
    Points : 4 238
    Points
    4 238
    Par défaut Re: 'Index' d'un ComboBox.AddItem : Valeurs désordonnées.
    En VB, la liste des index d'un combo n'est pas accessible, elle dépend de l'ordre des éléments de ton combo. par contre, pour associer tes éléments de List avec une valeur numérique, procède ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    With monCombo
         .AddItem "Nouvelles rubriques"
         .ItemData(.NewIndex) = 5
     
         .AddItem "Transport"
         .ItemData(.NewIndex) = 2
     
        '...
    End With
    Pour lire cette clé (Si monCombo.ListIndex > -1, sinon erreur à gérer) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    maCle = monCombo.ItemData(monCombo.ListIndex)
    maChaine = monCombo.List(monCombo.ListIndex)
    "Ce que l'on conçoit bien s'énonce clairement,
    Et les mots pour le dire arrivent aisément." Nicolas Boileau

    "Expliquer empêche de comprendre si cela dispense de chercher"

    Quiz Oracle : venez tester vos connaissances !

    La FAQ Oracle : 138 réponses à vos questions
    Aidez-nous à la compléter

  13. #13
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Salut Xo, c'est maintenant que tu arrives ?

    Adieu fabrice, tu es sauvé !

  14. #14
    Membre habitué
    Avatar de __fabrice
    Homme Profil pro
    Développeur Back-End
    Inscrit en
    Août 2004
    Messages
    404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Back-End

    Informations forums :
    Inscription : Août 2004
    Messages : 404
    Points : 194
    Points
    194
    Par défaut
    Merci à tous !, çà marche impec.


    Fabrice

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

Discussions similaires

  1. [ComboBox][Entête] Valeur au lieu d'index
    Par nikko49 dans le forum Ext JS / Sencha
    Réponses: 2
    Dernier message: 23/10/2013, 13h23
  2. [FLASH MX2004 pro] Combobox - addItem dynamique
    Par sanosuke85 dans le forum Flash
    Réponses: 4
    Dernier message: 08/01/2007, 14h08
  3. comboBox recup valeur data
    Par totoche dans le forum Flash
    Réponses: 2
    Dernier message: 26/10/2006, 11h58
  4. Connaitre l' Index d'une combobox
    Par auver dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 28/06/2006, 12h14
  5. [WinForms] ComboBox avec valeur non désirée
    Par Ditch dans le forum Général Dotnet
    Réponses: 14
    Dernier message: 11/04/2006, 16h52

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