28219 sujets

CSS et mise en forme, CSS3

Bonjour à tous,

Je me demande si je suis pas passé à coté d'un truc ! J'utilise un position:fixed sur un menu latéral. En testant sur IE 7, je me suis rendu compte que le menu était bien fixe mais complètement décalé sur la droite.
En fait il est décalé de la valeur de la marge externe gauche du div "contenu".

Pour l'instant, j'impose à IE 7 un position:static sur ce bloc de menu latéral pour pallier au problème mais j'aimerais comprendre ce phénomène.

Je joins le code HTML, il suffit de retirer le commentaire conditionnel pour voir le décalage:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
<head>
<title>title</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"/>
<meta http-equiv="Content-Language" content="fr"/>
<meta http-equiv="Content-style-type" content="text/css"/>
<link rel="stylesheet" type="text/css" media="screen" href="test.css"/>
<!--[if IE 7]>
<style>
#extra1 {position:static;}
</style>
<![endif]-->
</head>
<body>
<div id="page">	
	<div id="navigation">
		<ul><li><a href="#">item1</a></li><li><a href="#">item2</a></li><li><a href="#">item3</a></li><li><a href="#">item4</a></li><li><a href="#">item5</a></li><li><a href="#">item6</a></li><li><a href="#">item7</a></li></ul><div class="clea">&nbsp;</div>
	</div>
	
	<div id="extra1">
		<div class="box"><h4><span>titre</span></h4><ul><li><a href="#" title="title1">item1</a></li><li><a href="#" title="title2">item2</a></li><li><a href="#" title="title3">item3</a></li></ul></div>
	</div>	
	
	<div id="contenu">
		<h1><span>C'est un titre</span></h1>	
		<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum 
		ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet 
		erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum 
		augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices
		posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.</p>
	</div>
	
	<div id="pied">
		<p>c'est le pied !</p>
	</div>
</div>
</body>
</html>


et la feuille de style test.css :

html, body{
	margin:0;
	padding:0;
	height:100%;
}

body {
	font-family:Verdana, Arial, Helvetica, Geneva, sans-serif;
	font-size:75%;	
	background:#461301;
	color:#FFFFFF;
}

ul,ol {	margin: 0 1em;	padding: 0 1em;}
a {	text-decoration: underline;}
a:link,a:visited { color:#FFCC33;	background-color: transparent;}
a:hover,a:active { color: #FFCC33;	background: none;	text-decoration: none;}
.clea {clear:both;height:1px;}

#page {	
	position:relative;
	width: 760px;
	min-height: 100%;
	margin: 0 auto;
}

#navigation ul{
	margin:0 0.2em 0 0.2em;
}

#navigation li{
	font-size:1.2em;
	list-style-type:none;
	float:left;	
	padding:2px 1px;
	border-left:2px solid #A90160;
}

#navigation li a:link,#navigation li a:visited {
	padding:2px 2px;
}

#contenu {
	margin: 0 0 0 175px;
	padding:0 0.5em 4em 0.5em;
	color:#FFFFFF;
}

#contenu h1 {
	font-size:1.6em;
	margin-top:0;
}
 
#contenu p{
	margin-left:1em;
	margin-right:1em;
	color:#FFFFFF;
	line-height:1.4em;
}

#extra1 {
	position:fixed;
	float:left;
	width: 160px;	
	background-color:transparent;
	margin:0 0 4px 10px;
	color:#FFFFFF;
	text-align:right;	
}

#extra1 .box {
	margin:8px 0 2em 0;	
	border:2px solid #A90160;
}

#extra1 h4 {
	color:#83E151;
	margin:0;
	padding: 0 0.25em 0 40px;
	font-size:1.3em;
}

#extra1 ul {
	margin:0 0.25em 0.5em 18px;
	padding:0 0.25em 0 0;	
	list-style-type:none;
}

#pied {
	position: absolute;
	bottom: 0; 
	left:0;
	color:#C43787;
	height:3em;
	width: 100%;
	border:2px solid #A90160;
}


merci et bonne année à tous