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 :

cacher toutes les lignes ayant un identificateur commun


Sujet :

JavaScript

  1. #1
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut cacher toutes les lignes ayant un identificateur commun
    salut tout le monde,

    je voulais écrire une fonction permettant de cacher toutes les lignes de tableaux dans une page html, cette fonction va scanner tout la page et à chaque fois qu'elle rencontre une ligne dont l'identificateur est du type id="xxx" elle va le cacher s'il est affiché ou le contraire.

    quelqu'un a une idée ?

  2. #2
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 931
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 931
    Par défaut
    Ca veut dire quoi ayant un identificateur du type id="xxx" ?

    Un id est unique, rappelons-le ...

  3. #3
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut
    c vrai j'ai oublié ça !! mon problème que j'ai écrit la fonction suivante qui fait l'affaire
    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
     
    function clicMenu(num) {
     
    var i = 1;
    while ( i <= num)
    { 
       var m = document.getElementById("menu"+i);
     
       if(m.style.display == "none") {
     
         m.style.display = "";
     
       }
     
       else {
     
         m.style.display = "none";
     
       }
       i++;
     }
     }
    mais on doit lui passer le nombre de lignes à cacher en paramètre, or mon problème c'est que le code html est généré grâce à un fichier écrit en perl que j'ai trouvé beaucoup de problèmes à y introduire une variable qui compte le nombre de lignes, je veux une solution pour que la fonction cache toutes les lignes d'un seul coup sans avoir à connaître leur nombre ..

    merci.

  4. #4
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 931
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 931
    Par défaut
    Et pour replacer ton paramètre, tu peux utiliser ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var n = document.getElementById('iddetontableaudonttuveuxcachertoutesleslignes').getElementsByTagName('tr').length;

  5. #5
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut
    salut,
    j'ai modifié la fonction ainsi ais ça marche pas :
    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
    24
     
     
     function clicMenu() {
     var num = document.getElementByTagName("table").getElementsTagName("tr").length;
     
     var i = 1;
    while ( i <= num)
    { 
       var m = document.getElementById("menu"+i);
     
       if(m.style.display == "none") {
     
         m.style.display = "";
     
       }
     
       else {
     
         m.style.display = "none";
     
       }
       i++;
     }
     }
    des suggestions ?

  6. #6
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 931
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 931
    Par défaut
    getElementByTagName n'existe pas.
    getElementsTagName n'extiste pas.

    C'est getElementsByTagName et c'est un tableau.

    Donc si tu n'as qu'un seul <table> dans ta page :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var num = document.getElementsByTagName("table")[0].getElementsByTagName("tr").length;

  7. #7
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut
    salut,

    en faites je travaille sur un document comportant plusieurs tableaux, mais quand j'ai essayé la fonction avec le cas d'un seul j'obtient rien et ça m'embête car le code me paraît correct, voilà tout le code, le but est de cacher les lignes avec l'dentifiant "menu x" :
    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
     
     <html>
     <head>
     	<title>Untitled</title>
     <script>
     
     function clicMenu() {
     var num = document.getElementsByTagName("TABLE")[0].getElementsByTagName("tr").length;
     
     var i = 1;
     while ( i <= num)
     { 
       var m = document.getElementById("menu"+i);
     
       if(m.style.display == "none") {
     
         m.style.display = "";
     
       }
     
       else {
     
         m.style.display = "none";
     
       }
       i++;
     }
     }
     
     </script>
     </head>
     
     <body>
     <TABLE ID="con" BORDER="1" CELLPADDING="1" CELLSPACING="0" WIDTH="100%">
     <tr><a name="table_name"></a><td bgcolor=blue> <A HREF="path_for_data"><FONT SIZE=2><img src="path_for_image" width="15" height="10" border="0"></FONT></A> &nbsp; <FONT COLOR=FFFFFF><B>Results</B></FONT></td>
     <td bgcolor=blue align=center><FONT COLOR=FFFFFF><B>context1</B></FONT></td>
     <td bgcolor=blue align=center><FONT COLOR=FFFFFF><B>context2</B></FONT></td>
     <td bgcolor=blue align=center><FONT COLOR=FFFFFF><B>context3</B></FONT></td>
     <td bgcolor=blue align=center><FONT COLOR=FFFFFF><B>context4</B></FONT></td>
     <td bgcolor=blue align=center><FONT COLOR=FFFFFF><B>context5</B></FONT></td>
     </tr>
     <tr ><td colspan=6 align=left><B> <a href="javascript:void(0)" onclick="clicMenu();">tests</a></B></td></tr>
     <tr id="menu1" >
     <td align=left><A HREF="test1"><FONT SIZE=2><img src="path_for_image" width="15" height="10" border="0"></FONT></A> &nbsp; <A HREF="" ><FONT SIZE=2> 
     
       porcedure1
                          </FONT></A> </td>
     <td align=center>45</td>
     <td align=center><FONT COLOR="green"><B>45</B></FONT></td>
     <td align=center><FONT COLOR="green"><B>100.0</B></FONT></td>
     <td align=center><FONT SIZE=2>date</FONT></td>
     <td align=center><FONT SIZE=2> time</FONT></td>
     </tr>
     <tr id="menu2">
     <td align=left><A HREF="test2"><FONT SIZE=2><img src="path_for_image" width="15" height="10" border="0"></FONT></A> &nbsp; <A HREF=""><FONT SIZE=2>procedure2</FONT></A> </td>
     <td align=center>45</td>
     <td align=center><FONT COLOR="green"><B>45</B></FONT></td>
     <td align=center><FONT COLOR="green"><B>100.0</B></FONT></td>
     <td align=center><FONT SIZE=2>date</FONT></td>
     <td align=center><FONT SIZE=2> time</FONT></td>
     </tr>
     <tr><td align=left> <B>results1</td>
     <td align=center>90</td>
     <td align=center><FONT COLOR=orange><B>89</B></FONT></td>
     <td align=center><FONT COLOR=orange><B>98.9</B></FONT></td>
     <td align=center> - </td>
     <td align=center><FONT SIZE=2> total_time</FONT></td>
     </tr>
     <tr><td colspan=6 align=left><B>results2</td>
     <tr><td colspan=6 align=left><B>results3</B>  </td>
     <tr><td colspan=6 align=left><B>Statistics</B></td>
     <tr><td align=left><FONT SIZE=2>Total  </FONT></A></td>
     <td align=center>90</td>
     <td align=center><FONT COLOR=orange><B>89</B></FONT></td>
     <td align=center><FONT COLOR=orange><B>98.9</B></FONT></td>
     <td align=center> - </td><td align=center><FONT SIZE=2> total_times</FONT></td>
     </tr>
     </table>
     
     </body>
     </html>
    merci d'avance

  8. #8
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 931
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 931
    Par défaut
    Je viens de faire un c/c de ton code et il fonctionne, à un détail près.

    Tu devrais faire comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    while ( i <= num){ 
       var m = document.getElementById("menu"+i);
       if(m){
          if(m.style.display == "none") {
             m.style.display = "";
          }
          else {
             m.style.display = "none";
          }
       }
       i++;
    }

  9. #9
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut
    pourtant quand j'essaye d'exéuter ça j'obtient cette erreur dans la définition de var num " object doesn't support this property or method" est ce une erreur d'utilisation de méthodes ?

  10. #10
    LEK
    LEK est déconnecté
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    715
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 715
    Par défaut
    Ton navigateur ne supporte probablement pas la notation...
    En reprenant ta fonction initiale, et en étant sûr que le script perl ne produie pas de trous dans la séquence des id : tu peux sans doute procéder ainsi :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function clicMenu() {
    var i = 1;
    var m;
     while (  document.getElementById("menu"+i) )
     { 
       m = document.getElementById("menu"+i) ;
       m.style.display = (m.style.display=="none")?"":"none";
       i++;
      }
    }
    non ?

  11. #11
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    55
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 55
    Par défaut
    ça marche cette fois .. merci pour vous deux !!

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

Discussions similaires

  1. [XL-2003] Selectionner toutes les lignes ayant meme argument
    Par apnw7931 dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 02/02/2011, 16h06
  2. Réponses: 5
    Dernier message: 22/10/2010, 10h02
  3. Réponses: 3
    Dernier message: 28/04/2009, 00h42
  4. Réponses: 1
    Dernier message: 29/11/2005, 00h37
  5. Réponses: 4
    Dernier message: 11/10/2005, 15h03

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