Página web centrada vertical y horizontalmente
0Alguna vez te has preguntado "¿Y si creo una página con un ancho y alto fijos a modo de presentación en el que tan sólo una capa sea flexible?"
Buscando por internet llegué a un hilo en el que trataban éste tema, y me he tomado la libertad de terminar un poco el código (para añadirle un ancho a la web y que se autocentre).
El código CSS:
CSS:
- html, body {
- height: 100%;
- width: 100%;margin: 0;
- }
- #caja {
- display: table;
- height: 100%;
- width: 100%;
- position: relative;
- background:#000;
- }
- .centrado {
- display: table-cell;
- vertical-align: middle;
- margin: 0 auto;
- padding: 0 10px;
- height: 100%;
- background:#FFF;
- }
- .texto {
- position: relative;
- top: 0;
- display: block;
- background-color: #f00;
- color: #fff;
- width:400px;
- height: 300px;
- margin-left:auto;
- margin-right:auto;
- }
Y el código HTML:
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" lang="es-es">
- <meta http-equiv="content-type" content="text/html; charset=iso-8859-1" />
- <title>Centrado Vertical</title>
- </head>
- <div id="caja">
- <div class="centrado">
- <p class="texto">Texto de la página aquí</p>
- </div>
- </div>
- </body>
- </html>
Y el resultado sería algo como esto:
(Clic en la imagen para agrandar)
