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

HTML Discussion :

Afficher / cacher les elements d'un formulaire


Sujet :

HTML

  1. #1
    Membre éclairé Avatar de hisy
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    377
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 377
    Par défaut Afficher / cacher les elements d'un formulaire
    Bonjour,

    J'ai besoin de cacher et afficher des éléments d'un formulaire.
    Je parviens a cocher les éléments on utilisant cette fontion :
    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
     
    function hiddeElementByName(elem, isAjaxChooser){
        var element = document.getElementsByName(elem);
     
        element[0].style.display='none';
        var TD = element[0].parentNode;
        for(i=0; i < TD.childNodes.length; i++) {
          var element = TD.childNodes[i];
          if(element.nodeName == "IMG" || element.nodeName == "A" || element.nodeName == "SELECT" || element.nodeName == "TEXTAREA" || element.nodeName == "INPUT") {
            element.style.display='none';
          }
        }
        var prevTD = TD.previousSibling;
        if(isAjaxChooser == true ) var prevTD = prevTD.previousSibling;
        var SPAN = prevTD.firstChild;
        SPAN.style.visibility='hidden';
     
       }
    et je souhaiterai les ré-afficher avec cette fonction :

    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
    function showElementByName(elem, isAjaxChooser){
        var element = document.getElementsByName(elem);
        element[0].style.display='block';
        var TD = element[0].parentNode;
        for(i=0; i < TD.childNodes.length; i++) {
          var element = TD.childNodes[i];
          if(element.nodeName == "IMG" || element.nodeName == "A") {
            element.style.display='block';
          }
        }
        var prevTD = TD.previousSibling;
        if(isAjaxChooser == true ) var prevTD = prevTD.previousSibling;
        var SPAN = prevTD.firstChild;
        SPAN.style.visibility='visible';
     
          }
    }
    Mais le probleme c'est que les éléments (alignés avant d'être cachés)réapparaissent les uns en dessou des autres....

    Je précise que je travaille avec un framework qui construit les pages avec des tableaux html ... mais ca je peux pas y couper.
    nota : la cellule qui contient les élément à un nowrap ...

    Merci pour votre aide.

  2. #2
    Membre confirmé Avatar de Baldy
    Homme Profil pro
    Inscrit en
    Juin 2008
    Messages
    224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 224
    Par défaut
    "display" et "visibility" ne fonctionne pas de la même façon, tu as essayé de jouer avec les 2 pour voir si changeais quelque chose?

  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 : 55
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(element.nodeName == "IMG" || element.nodeName == "A") {
        element.style.display='block';
    }
    les balises a et img sont des balises de type inline, si tu les mets en display block, c'est normal que ça perturbe l'affichage
    Il est plutôt conseillé de mettre une chaine vide comme valeur :
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(element.nodeName == "IMG" || element.nodeName == "A") {
        element.style.display='';
    }
    du coup, c'est le type d'affichage par défaut (ou celui défini dans la feuille de style) qui est appliqué.
    Cette technique est particulièrement utile pour des éléments dont le display par défaut n'est pas ou mal géré en CSS (éléments de table par exemple).
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  4. #4
    Membre éclairé Avatar de hisy
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    377
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 377
    Par défaut
    Tip top ... merci beaucoup ...

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

Discussions similaires

  1. Rendre readonly tous les elements d'un formulaire.
    Par lemordore dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 11/10/2007, 12h26
  2. avoir les elements d'un formulaire
    Par etud_ini dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 15/09/2007, 21h32
  3. afficher tous les objets d'un formulaire
    Par sebhm dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 15/01/2007, 15h09
  4. Afficher / Cacher une partie d'un formulaire
    Par damjal dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 17/10/2005, 18h10

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