CSS Float: Tutorial Visual (I)
Float es una propiedad CSS que define un tipo de posicionamiento de los elementos de una página web. En el estándar se definen tres esquemas de posicionamiento para presentar elementos:
- Normal. (y aquí se incluye también el posicionamiento relativo).
- Absoluto.
- Flotante.
El flotante es, quizá, el menos intuitivo de los tres y el que presenta particularidades más ‘extrañas’ que intentaremos aclarar completamente en esta serie de dos tutoriales.
Conceptos Básicos
Para que un elemento flote utilizamos la propiedad float que puede tener los siguientes valores:
- left – Flota a la izquierda
- right – Flota a la derecha
- none – No flota, valor por defecto
- inherit – Hereda el valor del padre. No se utiliza porque en IE no funciona
Como vemos, un elemento no puede ser simplemente flotante, tiene que ser flotante a la derecha o flotante a la izquierda:
#elemento1 {
float: right;
}
#elemento2 {
float: left;
}
Que un elemento flote significa que intentará siempre desplazarse a la izquierda o a la derecha sobre la línea actual hasta chocar con el borde de su caja contenedora o de otro elemento flotante. Sólo otro elemento float puede interponerse entre él y el borde del contenedor. Veremos muchos ejemplos en los próximos apartados para entender todas las implicaciones de este comportamiento.
Hay cuatro reglas importantes que debemos tener en cuenta. Conociéndolas podremos siempre predecir dónde quedará un elemento si lo flotamos:

Las 4 reglas de oro de los float
Veremos también que este comportamiento se puede modificar con propiedades como clear o overflow.
Flotando Bloques
Vamos a empezar viendo cómo se comportan los elementos de bloque (divs en este ejemplo) cuando los flotamos. Trabajaremos con un documento con tres divs, cada uno con un fondo de color diferente.
En el HTML simplemente hemos declarado el título y tres divs vacíos dentro de un div (#wrapper) que los envuelve a todos:
<div id="wrapper"> <h1>Sólo Bloques (Divs)</h1> <div id="verde"></div> <div id="naranja"></div> <div id="azul"></div> </div>
Y en la hoja de estilos CSS les hemos puesto un borde punteado, altura, anchura y un color de fondo diferente para cada uno:
div#verde, div#naranja, div#azul {
width: 130px;
height:130px;
border:1px dotted black;
}
div#verde {
background-image: url(./images/verde.png);
}
div#naranja {
background-image: url(./images/naranja.png);
}
div#azul {
background-image: url(./images/azul.png);
}
La página se verá así en pantalla:

Tres bloques (div) sin float
Si asignamos float:right al bloque naranja se desplazará a la derecha y saldrá del flujo de elementos de la página para los otros elementos de bloque, que ocuparan su lugar como si no existiera:

Div naranja float:right
¿Y si lo flotamos hacia la izquierda?

div naranja float:left
¿Qué ha pasado? Lo mismo que antes, el bloque flotante (naranja) sale del flujo de elementos de la página, los bloques que están debajo ocupan su lugar como si no existiera (el azul sube). El naranja se coloca en su línea hacia la izquierda hasta el borde del contenedor tapando el bloque azul.
Para los elementos de bloque, las cajas flotadas están fuera del flujo de elementos de la página, no ocupan espacio
¿Y si flotamos también el bloque azul?¿qué ocurrirá?

Bloque naranja y azul con float:left
Como siempre, los bloques que están por encima no se ven afectados, el título (h1) y el bloque verde siguen en su sitio, pero por debajo nos llama la atención que el bloque contenedor (#wrapper) se ha encogido dejando fuera los dos bloques con float:left. La razón es sencilla, para los elementos de bloque (como el div contenedor, con borde negro en la imagen), los elementos flotantes no ocupan espacio en la página, por lo tanto no los tiene en cuenta. Veremos esto en detalle mas adelante y veremos también varias formas de evitarlo.
Para saber en que orden quedan los bloques es importante saber cómo están declarados en el código HTML. En este caso el naranja está primero, flota hacia la izquierda y sále del flujo de elementos, por lo que el azul sube a su misma línea, después éste también flota hacia la izquierda por lo que se intentará colocar al lado del borde o de otros elementos flotantes anteriores. En este caso le toca detrás del naranja.
Si flotamos también el verde el resultado es:

Los tres bloques float:left
¿Y si flotamos también el título, al fin y al cabo es otro elemento de bloque (h1)?

Todos los elementos float:left
Como el título es el primer elemento, flota en su línea a la izquierda, los demás elementos van subiendo y flotando en su misma línea detrás de él. Cuando no hay sitio en la misma línea se desplazan a la siguiente, donde hay hueco para seguir colocándose. Y mientras tanto, el div contenedor a lo suyo, encogiendo hasta casi desaparecer.
Cuando un elemento fotado cambia de línea por falta de espacio, es muy importante tener en cuenta la altura de las cajas de cada uno, porque el elemento se quedará donde tenga un hueco y puede quedar colocado de forma extraña:

Ejemplo de bloques descolocados. Los tres bloques son flotantes a la izquierda
El bloque azul ha quedado ‘enganchado’ en el verde porque es unos pixels más alto que el naranja. Al cambiar de línea quedará en el primer lugar que quepa, tocando al bloque de arriba. En este caso el problema se ve muy claro, pero cuando no tenemos fondos de color y un borde marcado, los elementos quedan descuadrados y el problema no se ve fácilmente.
La siguiente situación es parecida pero ahora el bloque azul es más ancho que la distancia que queda entre el verde y el borde del contenedor, como no cabe debajo del naranja, se irá hasta el extremo:

Ejemplo de bloques desordenados. Todos los bloques con float:left
Elementos de Línea. Imágenes y Texto
Las líneas de texto, y cualquier elemento de línea en general (span, em, strong, etc), adaptarán su longitud al colocarse al lado de un elemento flotante, para dejarle hueco.
Vamos a empezar viendo como se comportan las imágenes, que actúan como elementos de línea aunque en realidad son una mezcla, inline-block, porque fluyen en la línea pero tienen altura y anchura definible con width y height.
Veamos un documento con tres imágenes:

Ningún elemento flotante
¿Qué ocurrirá si flotamos el pez azul hacia la izquierda?
img#pezAzul {
float:left;
}
El pez azul se desplazará alegremente en su línea hacia la izquierda hasta el borde del contenedor (o hasta chocar con otro elemento flotante, pero en este caso no hay ninguno) y los otros elementos de línea (las otras dos imágenes), al estar al lado de un float, le harán hueco:

El pez azul con float:left
Si lo flotamos a la derecha:

Pez azul con float:right
La imagen se desplaza a la derecha hasta el borde y los otros elementos le dejan hueco.
¿Y si las imágenes estuvieran dentro de bloques, en un div?. Como siempre, para saber cómo van a quedar los elementos es importante saber en que orden están declarados en el código. Declaramos primero un título, luego la imagen del pez, y luego un div con borde rojo que contiene dos imágenes, la mariquita y el smiley:
<h1>Imágenes en Divs</h1> <img src="images/fish1.png"> <div class="bordeRojo"> <img src="images/bug.png"> <img src="images/smile.png"> </div>

Las dos imágenes de abajo están contenidas en un div
Si ahora flotamos la imagen del pez hacia la izquierda:

Pez azul con float:left
Lo que ocurre es lo siguiente:
- La imagen sále del flujo normal de elementos de la página por lo que no ocupa espacio (para los elementos de bloque)
- El bloque de abajo (con borde rojo) sube para ocupar su espacio
- Los elementos de línea (las 2 imágenes) se encuentran ahora al lado de un float y se desplazan para hacerle hueco
Este comportamiento se ve mucho más claro con las líneas de texto, que también son elementos de línea (faltaría mas) y normalmente están contenidas dentro de un párrafo (<p>…</p>) que es un elemento de bloque.
En el siguiente ejemplo tenemos un documento con un título, una imagen y un párrafo:

Sin floats
Si flotamos la imagen a la izquierda el bloque de texto subirá como si la imagen no existiera. Las líneas quedan ahora al lado de un float y se acortarán para fluir por el lado de la imagen:
Si la flotamos a la derecha:

Imagen con float:right
Terminando por hoy …
Aqui vamos a terminar la primera entrega de este tutorial, en la segunda parte veremos:
- Un amplísimo apartado sobre el uso de la propiedad clear, con numerosos ejemplos para ver cómo afecta a elementos de bloque y de línea, dependiendo de si son flotantes o no y cómo podemos utilizarlo para controlar la disposición de los elementos.
- Porqué se produce el ‘problema’ del contenedor, que se encoge hasta desaparecer cuando contiene elementos flotantes. Veremos que esto no es un error, sino una decisión de diseño, sabremos el porqué y varias formas diferentes de evitarlo.
- Cómo utilizar los floats para diseñar la estructura de una página.
Hasta el próximo tutorial! Deja tus comentarios si te ha gustado o si tienes alguna sugerencia.

muy bueno el post… un comentario…
yo cambiaría el “estar” por el “ser”… ejemplo:
en: “Como vemos, un elemento no puede estar simplemente flotado, tiene que estar flotado a la derecha o flotado a la izquierda:”
yo pondria:”Como vemos, un elemento no puede ser simplemente flotante, tiene que ser flotante a la derecha o a la izquierda”
y claro cambiaría “flotado” (más que nada por que no existe
) por “flotante”
Muy interesante tu comentario. La verdad es que estoy tan acostumbrado a escuchar ‘elemento flotado‘ que lo veo muy normal. He hecho una búsqueda en internet y aparece así en muchos tutoriales, pero tienes toda la razón, ‘flotado’ no existe… Creo que voy a tener que arremangarme y cambiarlo…
muy clarificador, buen trabajo, muy bueno realmente. Gracias.
Muy muy bien explicado… Haces facil de entender lo que no he conseguido entender en otros tutoriales….
Gracias de nuevo!