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

jQuery Discussion :

jQuery autocomplete avec un tableau à id


Sujet :

jQuery

  1. #1
    Membre éclairé Avatar de mLk92
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    527
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 527
    Par défaut jQuery autocomplete avec un tableau à id
    Salut à tous !!

    J'aimerais créer un champ d'autocompletion qui affiche une liste de nom, et lors de la sélection récupérer l'id du nom sélectionner pour le mettre dans un champ caché.

    Donc pour ça j'ai en html :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    <input type="text" id="filtre_nom" class="width: 300px;"/>
    <input type="text" id="filtre_nom_id_selected" value=""/>
    Et dans le JS, je rempli mon tableau avec des données en provenance d'un web service.

    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
     
    if(lstNom1.length > 0){
    	jQuery(xml).find('Nom1').each(function(){
    		var idNom1 = jQuery(this).find('id').text();
    		var nomNom1 = jQuery(this).find('libelle').text();
    		dataNom.push([idNom1, nomNom1]);
    	});
    }	
     
    if(lstNom2.length > 0){
    	jQuery(xml).find('Nom2').each(function(){
    		var idNom2 = jQuery(this).find('id').text();
    		var nomNom2 = jQuery(this).find('libelle').text();
    		dataNom.concat([idNom2, nomNom2]);
    	});
    }
    if(lstNom3.length > 0){
    	jQuery(xml).find('Nom3').each(function(){
    		var idNom3 = jQuery(this).find('id').text();
    		var nomNom3 = jQuery(this).find('libelle').text();
    		dataNom.concat([idNom3, nomNom3]);
    	});
    }
    Puis je fais l'autocompletion :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    jQuery("#filtre_client").autocomplete(dataNom, {
    	mustMatch: true,
    	matchContains: true
    }).result(function(event, data, formatted) {
    	if(data){
    		jQuery("#filtre_client_id_selected").val(data[0]);
    	}
    });
    Mon problème est qu'à chaque fois je ne remonte pas les bonnes infos... un coup il m'affiche que les id de la liste "Nom1", un coup rien du tout..

    J'ai l'impression que mon tableau est de forme dataNom[i][id, nom] car quand je fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    alert(dataNom[0]);
    il m'affiche la première ligne genre " 01 - robert " ...

    Comment faire pour que dans l'autocompletion j'ai bien ce que je veux , c'est à dire les libellés à l'affiche puis les ids lors de la sélection (result) ?

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    	jQuery(xml).find('Nom2').each(function(){
    		var idNom2 = $(this).attr('id');
    ?
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  3. #3
    Membre éclairé Avatar de mLk92
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    527
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 527
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    	jQuery(xml).find('Nom2').each(function(){
    		var idNom2 = $(this).attr('id');
    ?
    Là je pense que tu fais la même opération que :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    jQuery(xml).find('Nom1').each(function(){
    	var idNom1 = jQuery(this).find('id').text();
    });
    non ?

    Je pense que mon soucis est sur la forme du tableau :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataNom.push([idNom1, nomNom1]);
    Mais je ne vois pas trop comment faire

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    pas sur que l'on recupère la même chose sur l'id ...

    tu as declaré dataNom comme new Array()??
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataNom.push([idNom1, nomNom1]);
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  5. #5
    Membre éclairé Avatar de mLk92
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    527
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 527
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    pas sur que l'on recupère la même chose sur l'id ...

    tu as declaré dataNom comme new Array()??
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataNom.push([idNom1, nomNom1]);
    oui un peu avant dans la fonction j'ai :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var dataNom = new Array();

  6. #6
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    a priori ça ne vient pas de là...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var dataNom = new Array();
    dataNom.push(['un','deux'])
    dataNom.push(['trois','quatre'])
    alert('0=>'+dataNom[0]+'\n1=>'+dataNom[1])
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  7. #7
    Membre éclairé Avatar de mLk92
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    527
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 527
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    a priori ça ne vient pas de là...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var dataNom = new Array();
    dataNom.push(['un','deux'])
    dataNom.push(['trois','quatre'])
    alert('0=>'+dataNom[0]+'\n1=>'+dataNom[1])

    Donc en gros si je reprend ton code et le mien...

    Je construisait 3 ligne contenant chacune deux tableaux [id][nom] au lieu d'avoir un seul tableau de plusieurs lignes du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    id1 | nom1
    id2 | nom2
    id3 | nom3
    id4 | nom4
    id5 | nom5
    En fait il me faudrait une seule ligne de ce type [tabId[], tabNom[]], pour passer à l'autocompletion tabNom[] et avoir l'id correspondant dans tabId[] ?

  8. #8
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var dataNom = new Array();
    dataNom['un']='deux';
    dataNom['trois']='quatre'
    alert('un=>'+dataNom['un']+'\ndeux=>'+dataNom['deux'])
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

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

Discussions similaires

  1. JQuery Autocomplete avec post et json
    Par sapajou69 dans le forum jQuery
    Réponses: 1
    Dernier message: 18/12/2013, 13h59
  2. Réponses: 4
    Dernier message: 16/11/2010, 07h13
  3. Autocomplete avec JQuery - caractères avec accents
    Par DarkSeiryu dans le forum jQuery
    Réponses: 1
    Dernier message: 24/06/2010, 15h24
  4. [JQuery] Autocomplete, du mal avec Json
    Par supertino7 dans le forum jQuery
    Réponses: 4
    Dernier message: 21/09/2009, 18h25

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