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 :

Lister les ids d'une page HTML


Sujet :

JavaScript

  1. #1
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut Lister les ids d'une page HTML
    Bonjour,

    Je souhaite lister les id d'une page HTML, comment faire ?
    Le but de ma question est la suivante : J'ai un code HTML dans lequel j'ai plusieurs input de type text. Ces derniers ont déjà un name spécifique définit. Pour certains je fais une vérification de validité du texte tapé par l'utilisateur (par exemple, vérifier que le texte rentré est bien un entier. Je souhaiterais faire de même pour d'autres champs dont l'attribut name est déjà pris. Je me suis donc dit que je pourrais leur appliquer un id se nommant par exemple decimal1.
    Ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    <input type="text" name="prix01" id="decimal01" />
    <input type="text" name="prix02" id="decimal02" />
    Ainsi, dans mon javascript, je souhaite pouvoir lister tous les id de type decimalXX afin de faire ma vérification. Existe il une méthode javascript pour lister les id de ma page ? Si non, est possible de procéder autrement ou avez vous une autre idée de conception ?

    Merci

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,
    Spaffy a fait un script pour ça : getElement(s)ById filtré par une regExp

    A+.

  3. #3
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Sinon, tu peux aussi faire comme ça (en supprimant les 0 en préfixe) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    var i = 0;
    while(document.getElementById('decimal'+i){
        // Traitement ici
        i++;
    }

  4. #4
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    Je vais tester vos 2 réponses.
    Par contre Bovino, ta méthode implique de vérifier un certain nombre d'id qui peuvent ne pas exister. non ?

  5. #5
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Citation Envoyé par djibril Voir le message
    Par contre Bovino, ta méthode implique de vérifier un certain nombre d'id qui peuvent ne pas exister. non ?
    Dès que la boucle while rencontre un id qui n'existe pas, elle s'arrète .

  6. #6
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Dès que la boucle while rencontre un id qui n'existe pas, elle s'arrète .
    +1

    Ce qui implique qu'il n'y ait pas de trous dans la numérotation (pas de suppressions dynamiques) ...

    A+

  7. #7
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    Sauf que j'ai des situation où ça le hle tourne dans le vide car il n'y a pas de id à decimal 01 par exemple.

    J'ai opté pour cette solution

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
        // Vérification que les id de type decimalXX soit bien des décimales
        var LesTags = document.body.getElementsByTagName('*');
        var NombreElts     = LesTags.length;
        var regex_champ_decimal  = /^decimal\d\d$/;
        var regex_valeur_decimal = /^\d+,\d\d$/;
     
        for( var nbr_tag = 0; nbr_tag < NombreElts; nbr_tag++) {
          var mon_id = LesTags[nbr_tag]['id'];
          if ( regex_champ_decimal.test( mon_id ) && !regex_valeur_decimal.test( document.getElementById( mon_id ).value )  ) {
            alert( mon_id );
           }
        }
    J'ai juste un souci car il me trouve 8 fois le même id decimal01 alors qu'il n'est présent qu'une seul fois dans ma page.

  8. #8
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Par contre, là tu as intérêt à ce que ta page ne soit pas trop chargée par ailleurs, sinon, comme tu parcours tous les éléments de ta page, va y avoir un sérieux freeze
    Tu peux déjà restreindre la liste avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var LesTags = document.body.getElementsByTagName('input');
    A+

  9. #9
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    c'est vrai

  10. #10
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    Bon c'est ok. J'avais mis mon code dans un for, donc dans un mauvais emplacement, d'où la répétition.

    Merci à tous

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

Discussions similaires

  1. Supprimer les marges dans une page html
    Par Furius dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 12/01/2006, 04h41
  2. Réponses: 3
    Dernier message: 28/12/2005, 15h29
  3. Réponses: 7
    Dernier message: 14/09/2005, 10h50
  4. réinitialiser les liens d'une page html
    Par sisco dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 05/11/2004, 16h03

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