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 :

Menu déroulant et Firefox


Sujet :

JavaScript

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 7
    Par défaut Menu déroulant et Firefox
    Bonjour,

    J'ai récupéré un menu déroulant qui fonctionne parfaitement sous Internet Explorer mais pas sous Firefox :

    Voici le code :
    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
    <SCRIPT language=JavaScript>
    document.onmouseover = openIt; 
     
    function openIt()
    {
    	var items = 2;
    	currEl = window.event.toElement
    	if (currEl.className == "two")
    	{
    		newId = currEl.id + "box" 
    		showBox = document.all(newId) 
    		showBox.style.display = "block" 
    	}        
    	for (i=1; i<=items; i++)
    	{
    		openItem="item" + i + "box"
    		elOpen = document.all(openItem)
    			if ((elOpen.style.display == "block")&&(elOpen != showBox)) 
    					elOpen.style.display = "none" 
    			if (currEl.className == "closeIt")
    			{ 
    				elOpen.style.display = "none" 
    			} 
    	}
    }
     
    function closeIt()
    {
    	document.all.item1box.style.display = "none";
    	document.all.item2box.style.display = "none";
    }
     
    document.onclick = closeIt;
    </SCRIPT>
    Voici une partie du HTML :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    <span onMouseOut=closeIt()><a class="two" id="item1" href=#>Nos produits</a><br>
    <table class="box" id="item1box" onMouseOver="this.style.display = 'block'" style="DISPLAY: none" width="100%" cellpadding="2">
    	<tr><td><a class="sousmenu" href="index.php?to=caisses" title="Caisses">Caisses</a></td></tr>
    	<tr><td><a class="sousmenu" href="index.php?to=caisses_navette" title="Caisses navettes">Caisses navettes</a></td></tr>
    	<tr><td><a class="sousmenu" href="index.php?to=amenagements_calages" title="Caisses : aménagements et calages">Caisses : aménagements et calages</a></td></tr>
    	<tr><td><a class="sousmenu" href="index.php?to=palettes_emballages" title="Palettes et emballages divers">Palettes et emballages divers</a></td></tr>
    </table>
    </span>
    Quelqu'un aurait-il une idée sur le problème ?

    Merci,
    Franck

  2. #2
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Par défaut
    onMouseOut par onmouseout déja après a voir

  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 : Sélectionner tout - Visualiser dans une fenêtre à part
    currEl = window.event.toElement
    est spécifique IE, essaye plutôt :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    function openIt(e){
    ...
    var e=window.event || e
    currEl = window.event?e.toElement:e.relatedTarget;
    ...
    De plus, essaye aussi de terminer tes instructions par des ';'
    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 à l'essai
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 7
    Par défaut
    Merci pour votre aide.

    J'ai modifié comme vous l'avez indiqué mais ça ne fonctionne toujours pas avec Firefox . Sous IE, ça fonctionne toujours aussi bien .
    18% des visiteurs de mon site sont sous Firefox...
    Voici le lien de avec le menu en action, voir "Nos produits" et Nos services" http://www.ebs-france.com/zev2/index.php

    Merci,
    Franck


    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
    <SCRIPT language=JavaScript>	   
    document.onmouseover = openIt; 
     
    function openIt(e)
    {
    	var items = 2;
    	var e=window.event || e;
    	currEl = window.event?e.toElement:e.relatedTarget;
    	if (currEl.className == "two")
    	{
    		newId = currEl.id + "box"; 
    		showBox = document.getElementById(newId); 
    		showBox.style.display = "block"; 
    	}        
    	for (i=1; i<=items; i++);
    	{
    		openItem="item" + i + "box";
    		elOpen = document.getElementById(openItem);
    			if ((elOpen.style.display == "block")&&(elOpen != showBox)) 
    					elOpen.style.display = "none"; 
    			if (currEl.className == "closeIt")
    			{ 
    				elOpen.style.display = "none"; 
    			} 
    	}
    }
     
    function closeIt()
    {
    	document.all.item1box.style.display = "none";
    	document.all.item2box.style.display = "none";
    }
     
    document.onclick = closeIt;
    </SCRIPT>

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 7
    Par défaut Ca marche
    Oups, ça fonctionne !!!

    J'avais aussi oublié les guillemets après le href=

    <span onmouseout=closeIt()><a class="two" id="item1" href="#">

    Encore merci pour votre aide, c'est très sympa.
    Franck

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 7
    Par défaut Il reste un tout petit problème
    Re-bonjour,

    Il reste une tout petit problème :
    - sous IE le menu se déroule dès que l'on est sur le lien
    - sous Firefox il faut descendre la souris pour que le menu se déroule

    Une idée pour que ça fasse la même chose que sous IE ?

    Merci,
    Franck

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 7
    Par défaut Menu déroulant avec Firefox
    Bonjour,

    Je laisse le lien vers le site avec le menu déroulant en action :
    http://www.ebs-france.com/zev2/

    Si quelqu'un a une idée concernant le fait que sous Firefox je dois descendre le curseur de la souris pour que le menu se déroule.

    Merci d'avance.
    Franck

  8. #8
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Par défaut
    testé sous ie 7 et FF3 :

    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
     
    <html>
    <head>
    	<title>menu</title>
    	<style type="text/css">
    		.menu li{
    			float:left;
    			display:block;
    			width:150px;
    			position:relative;
    			padding:0px;
    			margin:0px 5px 0px 0px;
    			background-color:red;
    		}
     
    		.menu li:hover .SousMenu{
    			display:block;
    		}
     
    		.SousMenu{
    			position:absolute;
    			left:0px;
    			top:20px;
    			display:none;
    			margin:0px;
    			padding:0px;
    		}
    		.SousMenu li{
    			float:left;
    			clear:both;
    		}
    	</style>
    	<script type="text/javascript">
    		function UpDown(me,etat)
    		{
    			var HaveChild = (me.getElementsByTagName('ul').length > 0) ? true:false;
    			if(HaveChild)
    			{
    				me.getElementsByTagName('ul')[0].style.display = (etat)? "block":"none";
    			}
    		}
     
    		function initMenu(){
    			var listeLi = document.getElementById('menu').getElementsByTagName('li');
    			for(var i = 0  , l = listeLi.length ; i <l ; i++){
    				listeLi[i].onmouseover = function(){UpDown(this,true);};
    				listeLi[i].onmouseout = function(){UpDown(this,false);};
     
    			}
    		}
    	</script>
    </head>
    <body>
    <ul class="menu" id="menu">
    	<li>Accueil</li>
    	<li>Présentation</li>
    	<li>Nos produits
    	<ul class="SousMenu">
    		<li>Caisses</li>
    		<li>Caisses navettes</li>
    		<li>Caisses : aménagements et calages</li>
    		<li>Palettes et emballages divers</li>
    	</ul>
    	</li>
    	<li>
    	 	Nos services
    		<ul class="SousMenu">
    			<li>Emballage industriel</li>
    			<li>Mise en container</li>
    			<li>Livraison</li>
    		</ul>
    	</li>
    	<li>Contact</li>
     
    </ul>
    <script type="text/javascript">initMenu();</script>
    </body>
    </html>
    un peu plus propre a mon gout tu n'a plus qu'a modifier les couleurs

  9. #9
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 7
    Par défaut J'ai testé
    Bonsoir,

    C'est vrai que c'est chouette quand il n'y a pas d'erreurs , je ne suis pas habitué...
    Je l'ai testé, il fonctionne super bien : http://www.ebs-france.com/zev2/zmenu.php

    Le petit problème c'est que maintenant il faut que je le mette en forme .
    Bon pour la couleur de fond, pas de problème.
    J'ai essayé de trafiquer le code CSS mais je ne vois pas bien où je dois ajouter mes xxx:link {text-decoration: none; font-family:Verdana; font-size:7.5pt; font-weight: bold; color: #FFFFFF} ... etc pour les liens des "sous menus" et également pour mettre la police du "menu" (Nos produits et Nos Services) xxx:link {text-decoration: none; font-family:Verdana; font-size:7.5pt; font-weight: bold; color: #FFFFFF} ... etc.

    J'abuse, je sais. Mais je fais des efforts.

    Merci pour ton aide,
    Franck

  10. #10
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Par défaut
    testé en ligne par rapport a ton menu voici le css :

    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
     
    .menu li{
    			float:left;
    			display:block;
    			width:150px;
    			position:relative;
    			padding:4px;
    			margin:0px 0px 0px 0px;
    			background-color:#406198;
    			text-align:center;
    			font-family:Verdana;
    			font-size:7.5pt;
    			font-weight: bold;
    			color: #FFFFFF
    		}
     
    		.menu li a{
    			text-align:left;
    			text-decoration: none;
    display:block;
    color:#FFFFFF;
    		}
    		.menu li a:hover{
    			color:#89BA0A;
    		}
     
     
    		.menu li:hover .SousMenu{
    			display:block;
    		}
     
    		.SousMenu{
    			position:absolute;
    			left:0px;
    			top:20px;
    			display:none;
    			margin:0px;
    			padding:0px;
    		}
    		.SousMenu li{
    			float:left;
    			clear:both;
    		}
    seule différence , la largeur du menu , et le fait que les liens soient sur deux lignes si trop long

  11. #11
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 7
    Par défaut J'exagère
    Bonsoir,

    C'est nickel, tu me maches le travail... Mais je m'apperçois que je suis vraiment larguer. Depuis fin 2003/début 2004 je ne me suis pas replonger là dedans (PHP, CSS). Le prochain site, c'est un pro qui le fera !

    Je ne parviens pas à reproduire la présentation initiale avec mon menu "plein d'erreurs", est-ce qu'il est possible de réduire la largeur (width:150px pour le menu principal (Accueil, Présentation, Nos produits, Nos services, Contact) et de mettre les 2 boites qui se déroulent à une taille différente ?
    Ton menu en action : http://www.ebs-france.com/zmenu.php
    Le menu "plein d'erreurs" en action : http://www.ebs-france.com/ avec la présentation souhaitée.

    Merci beaucoup,
    Franck

Discussions similaires

  1. Pb menu déroulant sous Firefox, mais fonctionnel sous IE7
    Par manu-lyon dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 09/05/2009, 19h26
  2. Menu déroulant avoir le meme résultat sur IE et FireFox.
    Par aityahia dans le forum Mise en page CSS
    Réponses: 3
    Dernier message: 19/03/2008, 22h08
  3. Menu déroulant entre Firefox et IE7
    Par asagtoth dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 21/02/2008, 13h02
  4. Menu déroulant : pb compatibilité Firefox / IE 6 & 7
    Par aragorn23 dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 31/08/2007, 10h13
  5. problème de menu déroulant sous firefox
    Par jeromed1 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 10/11/2006, 13h55

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