28111 sujets

CSS et mise en forme, CSS3

Bonjour à tous !

Voilà mon problème, je crée actuellement un site grâce au CMS Joomla!, et j'utilise un menu tiré d'un module à part.

J'ai fait quelques changements qui marchent très bien, hélas il y'a un problème sous IE (mais cela marche nickel sous Firefox) :

Les sous menus du menu déroulant passent derrière les cadres de mon site...

Voici le CSS pour ceux que ça pourrait aider :


/*** ESSENTIAL STYLES ***/
.sf-menu, .sf-menu * {
	margin:			0;
	padding:		0;
	list-style:		none;
}
.sf-menu {
	line-height:	1.0;
}
.sf-menu ul {
	position:		absolute;
	top:			-999em;
	width:			10em; /* left offset of submenus need to match (see below) */
}
.sf-menu ul li {
	width:			100%;
}
.sf-menu li:hover {
	visibility:		inherit; /* fixes IE7 'sticky bug' */
}
.sf-menu li {
	float:			left;
	position:		relative;
}
.sf-menu a {
	display:		block;
	position:		relative;
}
.sf-menu li:hover ul,
.sf-menu li.sfHover ul {
	left:			0;
	top:			2.5em; /* match top ul list item height */
	z-index:		99;
}
ul.sf-menu li:hover li ul,
ul.sf-menu li.sfHover li ul {
	top:			-999em;
}
ul.sf-menu li li:hover ul,
ul.sf-menu li li.sfHover ul {
	left:			10em; /* match ul width */
	top:			0;
}
ul.sf-menu li li:hover li ul,
ul.sf-menu li li.sfHover li ul {
	top:			-999em;
}
ul.sf-menu li li li:hover ul,
ul.sf-menu li li li.sfHover ul {
	left:			10em; /* match ul width */
	top:			0;
}

/*** DEMO SKIN ***/
.sf-menu {
	float:			left;
	margin-bottom:	1em;
}
.sf-menu a {
	border-left:	1px solid #fff;
	border-top:		1px solid #CFDEFF;
	padding: 		.75em 1em;
}
.sf-menu a, .sf-menu a:visited , .sf-menu a:link { /* visited pseudo selector so IE6 applies text colour*/
	color:		white;      /* #13a; */
	text-decoration:	none;
	font-weight: bold;
	font-family: "Lucida Grande", " Arial Black", Arial;
	text-align: center;
	/*font-variant: small-caps;*/

}

.sf-menu li {
	background:		#999999;
}
.sf-menu li li {
	background:		#999999; /*#AABDE6;*/
}
.sf-menu li li li {
	background:		#999999; /*#9AAEDB;*/
}

.sf-menu li:first-child, .sf-menu li.first-child {
}

.sf-menu li:last-child, .sf-menu li.last-child {
}

.sf-menu li:hover, .sf-menu li.sfHover,
.sf-menu a:focus, .sf-menu a:hover, .sf-menu a:active {
	background:		#999999;  /*#CFDEFF;*/
	outline:		0;
	color : #FFCF4D;
	text-decoration : none;
}



.sf-menu li .separator {
	display: block;
	border-left:	1px solid #fff;
	border-top:		1px solid #CFDEFF;
	padding: 		.75em 1em;
}


/*** arrows **/
.sf-menu a.sf-with-ul {
	text-decoration:	none;
	padding-right: 	2.25em;
	min-width:		1px; /* trigger IE7 hasLayout so spans position accurately */
}
.sf-sub-indicator {
	text-decoration:	none;
	position:		absolute;
	display:		block;
	right:			.75em;
	top:			1.05em; /* IE6 only */
	width:			10px;
	height:			10px;
	text-indent: 	-999em;
	overflow:		hidden;
	background:		url('../images/arrows-ffffff.png') no-repeat -10px -100px; /* 8-bit indexed alpha png. IE6 gets solid image only */
}
a > .sf-sub-indicator {  /* give all except IE6 the correct values */
	top:			.8em;
	background-position: 0 -100px; /* use translucent arrow for modern browsers*/
}
/* apply hovers to modern browsers */
a:focus > .sf-sub-indicator,
a:hover > .sf-sub-indicator,
a:active > .sf-sub-indicator,
li:hover > a > .sf-sub-indicator,
li.sfHover > a > .sf-sub-indicator {
	background-position: -10px -100px; /* arrow hovers for modern browsers*/
}

/* point right for anchors in subs */
.sf-menu ul .sf-sub-indicator { background-position:  -10px 0;	text-decoration:	none; }
.sf-menu ul a > .sf-sub-indicator { background-position:  0 0; 	text-decoration:	none;}
/* apply hovers to modern browsers */
.sf-menu ul a:focus > .sf-sub-indicator,
.sf-menu ul a:hover > .sf-sub-indicator,
.sf-menu ul a:active > .sf-sub-indicator,
.sf-menu ul li:hover > a > .sf-sub-indicator,
.sf-menu ul li.sfHover > a > .sf-sub-indicator {
	background-position: -10px 0; /* arrow hovers for modern browsers*/
}

/*** shadows for all but IE6 ***/
.sf-shadow ul {
	background:	url('../images/shadow.png') no-repeat bottom right;
	padding: 0 8px 9px 0;
	-moz-border-radius-bottomleft: 17px;
	-moz-border-radius-topright: 17px;
	-webkit-border-top-right-radius: 17px;
	-webkit-border-bottom-left-radius: 17px;
}
.sf-shadow ul.sf-shadow-off {
	background: transparent;
}

.sf-menu .active {
	background: #999999;/*         ---------- Modifie le lien du menu de la page active -------- */
}

.sf-menu #current {
	background: #999999; /*#aaa; --------- Fond de la catégorie active  */
	text-decoration : orange;
}

.superfish_clear { 
	clear: both !important;
	height: 1px !important;
	overflow: hidden !important;
	font-size: 1px !important;
	margin: 0 !important;
	padding: 0 !important;
}



Merci à ceux qui pourront m'aider à résoudre mon problème Smiley smile
Modifié par StyveA (11 Aug 2010 - 16:49)
Bonsoir,
j'ai pas regardé le code en détail mais essaye de voir si un position:relative sur le sfmenu ne règle pas le problème Smiley cligne
Il y'a un z-index ici :

.sf-menu li:hover ul,
.sf-menu li.sfHover ul {
	left:			0;
	top:			2.5em; /* match top ul list item height */
	z-index:		99;
}


cela n'est il pas suffisant?
bonjour du jour...

Bon oui y a un z-index...

par contre est il suffisant par rapport aux autres z-index ???

il faut que tu sois sur que ce z-index à 99 soit supérieur aux autres pour pouvoir passer au dessus des autres div...

fait des essais en augmentant cette valeur... mets là à 10000 par exemple...
Bonjour bonjour !

Je viens de modifier sa valeur et d'essayer avec plusieurs nombres pour finir par : 1000000000000000000000000

Mais ça ne fonctionne toujours pas =/

Quant au position:relative, il fait buggé le menu :s

Le problème doit venir d'ailleurs non?
Modifié par StyveA (11 Aug 2010 - 15:34)
Bon bah résolu ^^'

Il m'a suffit de rajouter un position : relative au niveau des sous menus ,j'avais pas fait attention mais là c'était uniquement pour les menus de base