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

JavaScript Discussion :

Récupérer des balises dont l'id est un tableau


Sujet :

JavaScript

  1. #1
    Membre éclairé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 578
    Points : 804
    Points
    804
    Par défaut Récupérer des balises dont l'id est un tableau
    Bonjour,

    Dans un script dont le but est de sélectionner des colonnes de tables de données et de leur affecter un format d'impression, je voudrais récupérer des balises input dont l'id est un tableau généré en php.

    Chaque id et nom de balise sont de la forme var_nom_table[var_nom_champ][print] où seul print est une chaîne constante et j'ai besoin de récupérer uniquement les balises dont la deuxième dimension est justement ce print.

    L'id et le nom sont identiques.

    Pour info voici le bout de code qui génère les noms et les id des balises input (tabLine (objet $line) et tabCell sont des classes perso pour faciliter l'écriture de tableau) :
    Code php : 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
    <?php
            $keyName = $table.'['.$colKey.']';
            $categories = ['print', 'bold', 'italic', 'family', 'size'];
            $i = 0;
            foreach ($categories as &$category) {
                $tagNames[$i] = $keyName.'['.$categories[$i].']';
                $i++;
            }
            //var_dump($tagNames);
            $line->addCell(new tabCell("<input type='checkbox' name='$tagNames[0]' id='$tagNames[0]' onchange='onMajChk()' />"));
            $line->addCell(new tabCell("<input type='checkbox' name='$tagNames[1]' id='$tagNames[1]' />"));
            $line->addCell(new tabCell("<input type='checkbox' name='$tagNames[2]' id='$tagNames[2]' />"));
            //$line->addCell(new tabCell("<input type='checkbox' name='$tagNames[3]' id='$tagNames[3]' />")); // A remplacer par liste de choix
            $line->addCell(new tabCell("<input type='number' name='$tagNames[4]' id='$tagNames[4]' min='8' max='16' value='10' />"));
            $lines .= $line;
    ?>

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    16 959
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Bonjour,
    tu peux utiliser la méthode querySelectorAll(selecteur) en ciblant via un sélecteur [id*="print"], par exemple, pour récupérer les éléments dont l'ID contient print.

  3. #3
    Membre éclairé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 578
    Points : 804
    Points
    804
    Par défaut
    Bonjour,
    Je ne comprends pas ton écriture du sélecteur. J'ai regardé le tuto et je ne comprends toujours pas.
    Est-ce que le sélecteur doit obligatoirement figurer dans une feuille de style?
    Voici mes essais:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	function onMajAll() {
    		alert('fonction appelée');
    		var status = window.document.getElementById('all'),
    			//checkboxes['print'] = window.document.querySelectorAll('[id*="print"]');
    			//checkboxes['print'] = window.document.querySelectorAll('id=*"[print]"');
    			checkboxes['print'] = window.document.querySelectorAll('#=*"[print]"');
    		alert(checkboxes);
    	}

  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 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut
    un id tableau ?
    a ma connaissant l'id est de type string ... donc pas du tout interprété comme un tableau !

    Pour ce qui est du sélecteur Commence par print, aura un scope plus réduit
    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é
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 578
    Points : 804
    Points
    804
    Par défaut
    Non ça ne fonctionne pas non plus. Est-ce que tu peux m'écrire toute l'expression. Le problème est peut-être dans mon écriture.
    Je suis d'accord, le tableau est interprété ici comme une chaîne. L'écriture sous forme de tableau est pour l'exploitation en php.
    J'ai (provisoirement ?) résolu le problème en créant une classe fictive.

  6. #6
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    Et comme ça ?

    Code html : 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
    <script>
    function toto() {
      var coll = document.querySelectorAll('input.print');
      alert(coll.length);
    }
    </script>
    <input class="print" type='checkbox' name='var_nom_table[1][print]' id='var_nom_table[1][print]' /><br/>
    <input class="print" type='checkbox' name='var_nom_table[2][print]' id='var_nom_table[2][print]' /><br/>
    <input class="print" type='checkbox' name='var_nom_table[3][print]' id='var_nom_table[3][print]' /><br/>
    <input class="print" type='checkbox' name='var_nom_table[4][print]' id='var_nom_table[4][print]' /><br/>
    <input class="print" type='checkbox' name='var_nom_table[5][print]' id='var_nom_table[5][print]' /><br/>
    <input class="print" type='checkbox' name='var_nom_table[6][print]' id='var_nom_table[6][print]' /><br/>
    <input class="bold" type='checkbox' name='var_nom_table[1][bold]' id='var_nom_table[1][bold]' /><br/>
    <input class="bold" type='checkbox' name='var_nom_table[2][bold]' id='var_nom_table[2][bold]' /><br/>
    <input class="bold" type='checkbox' name='var_nom_table[3][bold]' id='var_nom_table[3][bold]' /><br/>
    <input class="bold" type='checkbox' name='var_nom_table[4][bold]' id='var_nom_table[4][bold]' /><br/>
    <input class="bold" type='checkbox' name='var_nom_table[5][bold]' id='var_nom_table[5][bold]' /><br/>
    <input type="button" value="Clic" onclick="toto()" />
    Cela ne sert à rien d'optimiser quelque chose qui ne fonctionne pas.

    Mon site : www.emmella.fr

    Je recherche le manuel de l'Olivetti Logos 80B.

  7. #7
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    16 959
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Citation Envoyé par smccbbm
    Non ça ne fonctionne pas non plus.
    Nous voilà bien avancé, mais cela n'a rien d'étonnant compte tenu de la façon dont tu as de t'en servir.
    Utilisation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var mesElements = document.querySelectorAll('[id*="print"]');   // qui contiennent « print »
    var mesElements = document.querySelectorAll('[id$="[print]"]'); // qui se terminent par « [print] »
    Ceci étant et attendu que
    le but est de sélectionner des colonnes de tables de données et de leur affecter un format d'impression
    la solution de passer par une classe me paraît plus judicieuse, voir la mise en oeuvre de badaze.

    [EDIT] correction coquille.

  8. #8
    Membre éclairé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 578
    Points : 804
    Points
    804
    Par défaut
    Merci pour vos réponses.
    La solution de badaze est celle que j'avais adoptée avant même d'avoir lu son message (mon message d'hier 19h33) et ça fonctionne très bien.
    Par contre dans tes exemples avec l'id, je ne comprends pas pourquoi on ne referme pas le crochet à la fin?

  9. #9
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    16 959
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    je ne comprends pas pourquoi on ne referme pas le crochet à la fin?
    simplement une erreur de ma part, corrigée !

    Résolue donc ?

  10. #10
    Membre éclairé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 578
    Points : 804
    Points
    804
    Par défaut
    OK, merci. Je marque résolu.

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

Discussions similaires

  1. [XSLT] des noeuds dont le contenu est forcément différent
    Par DelphLaga dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 13/10/2006, 19h06
  2. Réponses: 2
    Dernier message: 05/10/2006, 14h58
  3. Réponses: 3
    Dernier message: 14/07/2006, 20h24
  4. [MySQL 4.0.24] Compter des dossiers dont un champ est vide
    Par boniface dans le forum Langage SQL
    Réponses: 2
    Dernier message: 30/06/2006, 14h29
  5. [VB.Net] Afficher des données dont la valeur est nulle
    Par badnane2 dans le forum Windows Forms
    Réponses: 3
    Dernier message: 06/06/2006, 13h23

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