Ben prenez le code de l'exemple 3 (http://www.alsacreations.com/xmedia/tuto/exemples/3colonnes/exemple-3.html) et mettez du texte très long
et voilà ça :
edit: url : madri2.free.fr/exemple-3.html
<!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>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Exemple : bloc central sans marges, mais avec un contexte de formatage</title>
<style type="text/css">
html {font-size: 100%;}
body {padding: 1em; font-size: .85em; font-family: Verdana, "Bitstream Vera Sans", "Lucida Grande", sans-serif;}
h1 {margin-top: 0; text-align: center; background: moccasin;}
ol, ul, li {padding: 0; margin: 1em;}
div#colonne1 {
float: left;
width: 160px;
margin-right: 10px;
padding: 1px 0;
background: lightblue;
}
div#colonne2 {
float: right;
width: 300px;
margin-left: 10px;
padding: 1px 0;
background: burlywood;
}
div#centre {
overflow: hidden;
padding: 1px 20px;
background: khaki;
}
</style>
<!--[if lte IE 6]><style type="text/css">
div#colonne1 {
margin-right: 7px;
}
div#colonne2 {
margin-left: 7px;
}
div#centre {
overflow: visible;
height: 1%;
display:inline-block;
}
</style><![endif]-->
</head>
<body>
<h1>Exemple : bloc central sans marges, mais avec un contexte de formatage</h1>
<div id="colonne1">
<h2>Navigation</h2>
<ul>
<li><a href="http://css.alsacreations.com/Faire-une-mise-en-page-sans-tableaux/design-trois-colonnes-positionnement-flottant">Tutoriel : un design fluide avec trois colonnes Ÿ</a></li>
<li><a href="exemple-1.html">Exemple : bloc central sans marges</a></li>
<li><a href="exemple-2.html">Exemple : bloc central avec marges compensant les flottants</a></li>
<li><strong>Exemple : bloc central sans marges, mais avec un contexte de formatage</strong></li>
</ul>
</div><!-- fin de div#colonne1 -->
<div id="colonne2">
<h2>Code CSS</h2>
<pre>div#colonne1 {
float: left;
width: 160px;
margin-right: 10px;
background: lightblue;
}
div#colonne2 {
float: right;
width: 300px;
margin-left: 10px;
background: burlywood;
}
div#centre {
overflow: hidden;
background: khaki;
}</pre>
<p>Et via un commentaire conditionnel visant Internet Explorer 6 et inférieurs :</p>
<pre>div#colonne1 {
margin-right: 7px;
}
div#colonne2 {
margin-left: 7px;
}
div#centre {
overflow: visible;
height: 1%;
}</pre>
</div><!-- fin de div#colonne2 -->
<div id="centre">
<h2>Explications</h2>
<div style="clear:both;"></div>
<ol>
<li>Les deux colonnes aux extrémités sont dotées de <strong>largeurs fixes</strong>, et sont <strong>flottantes</strong> à gauche et à droite. Par conséquent, elles "flottent" <strong>par dessus</strong> les autres blocs (et n'en repoussent que le texte ou les images et éléments en-ligne), en l'occurence par dessus notre colonne centrale.</li>
<li>Ce conteneur central <strong>n'a pas de largeur fixe, et il n'est pas flottant</strong>. Il prend donc 100% de la largeur disponible, soit <strong>toute la largeur</strong>, car les flottants ne sont pas pris en compte.</li>
<li>Enfin, pour éviter que les limites (bordures, fond) du bloc conteneur central ne s'affichent par dessous les flottants, on rajoute à ce conteneur <strong>un contexte de formatage</strong> à l'aide de la propriété <code>overflow</code>.</li>
<li>Accessoirement, de petites marges <em>ajoutées aux flottants</em> permettent de créer un retrait entre le bloc central et les flottants.</li>
</ol>
<p>Et le tour est joué… du moins pour les navigateurs qui appliquent les contextes de formatage. Pour les autres (pour l'essentiel : Internet Explorer 5 et 6), quelques petits correctifs sont nécessaires.</p>
<div style="color: #9a7; margin-top: 50px;">
<h2>Du texte de remplissage</h2>
<p>LoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLoremLorem 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>
<p>Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce varius, ligula non tempus aliquam, nunc turpis ullamcorper nibh, in tempus sapien eros vitae ligula. Pellentesque rhoncus nunc et augue. Integer id felis. Curabitur aliquet pellentesque diam. Integer quis metus vitae elit lobortis egestas. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Morbi vel erat non mauris convallis vehicula. Nulla et sapien. Integer tortor tellus, aliquam faucibus, convallis id, congue eu, quam. Mauris ullamcorper felis vitae erat. Proin feugiat, augue non elementum posuere, metus purus iaculis lectus, et tristique ligula justo vitae magna.</p>
</div>
</div><!-- fin de div#centre -->
</body>
</html>
edit2:
ALors bon me dire, pourquoi mettre autant de texte etc etc.
Mais il suffit que sur un forum quelqu'un poste une image trop grosse ou s'amuse à mettre du texte sans espace et on se retrouve avec le tout collé en bas (mais juste sur ie6 heuresement)
edit3:
en utilisant un tableau, le texte trop grand va faire allonger la fenetre au lieu ici de couper ce qui dépasse.
S'il existe un moyen de faire ça et qui soit compatible ie6...
Parce que j'ai beau éplucher le net il n'y a rien qui soit compatible "texte très long".
edit4 (version 46464, fichues balises qui supportent pas le majuscule):
voici une image du magnifique ie6:
http://img150.imageshack.us/img150/6333/fuckie6.th.png Modifié par madri2 (25 Aug 2009 - 20:05)