clear

La propiedad CSS clear especifica si un elemento puede estar al lado de elementos flotantes que lo preceden o si debe ser movido (cleared) debajo de ellos. La propiedad clear aplica a ambos elementos flotantes y no flotantes.

Cuando es aplicado a bloques no flotantes, mueve el border edge (en-US) del elemento hacia abajo hasta que este debajo del margin edge (en-US) de todos los floats relevantes. Este movimiento (cuando acontece) causa que margin collapsing (en-US) no ocurra.

Cuando se aplica a elementos flotantes, mueve el margin edge (en-US) del elemento debajo del margin edge (en-US) de todos los floats relevantes. Esto afecta la posici贸n de floats posteriores, ya que estos no pueden ser posicionados m谩s arriba que los primeros.

Los floats que son relevantes para ser limpiados (cleared) son los primeros floats dentro del mismo contexto de formato de bloque.

Nota: Si deseas que un elemento contenga todos los elementos flotantes dentro, puedes hacer dos cosas, o bien flotar el contenedor tambi茅n o usar clear en un pseudo-element ::after.

#container::after {
   content: "";
   display: block;
   clear: both;
}

Valor inicialnone
Applies toblock-level elements
Heredableno
Valor calculadocomo se especifica
Animation typediscrete

Sintaxis

clear: none;
clear: left;
clear: right;
clear: both;
clear: inline-start;
clear: inline-end;

clear: inherit;

Valores

none
Es un keyword que indica que el elemento no es movido hacia abajo para limpiar elementos flotantes anteriores.
left
Es un keyword que indica que el elemento es movido hacia abajo para limpiar elementos flotantes a la izquierda.
right
Es un keyword que indica que el elemento es movido hacia abajo para limpiar elementos flotantes a la derecha.
both
Es un keyword que indica que el elemento es movido hacia abajo para limpiar tanto elementos flotantes de la izquierda como de la derecha.
inline-start This is an experimental API that should not be used in production code.
Es un keyword que indica que el elemento es movido hacia abajo para limpiar elementos flotantes al inicio del bloque contenedor, estos son los elementos con valor float left en scripts ltr (left to right) y elementos con valor float right en scripts rtl (right to left).
inline-end This is an experimental API that should not be used in production code.
Es un keyword que indica que el elemento es movido hacia abajo para limpiar floats al final del bloque contenedor, estos son los elementos con valor float right en scripts ltr (left to right) y elementos con valor float left en scripts rtl (right to left).

Sintaxis formal

none | (en-US) left | (en-US) right | (en-US) both | (en-US) inline-start | (en-US) inline-end

Ejemplo

Nota: El div con clase 'wrapper' a帽ade un borde para una mejor visibilidad de la utilidad de la propiedad clear

clear: left

Contenido HTML

<div class="wrapper">

    <p class="black">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Phasellus sit amet diam. Duis mattis varius dui. Suspendisse eget dolor.</p>

    <p class="red">Lorem ipsum dolor sit amet, consectetuer adipiscing elit.</p>

    <p class="left">This paragraph clears left.</p>

</div>

Contenido CSS

.wrapper{
    border:1px solid black;
    padding:10px;
}
.left {
    border: 1px solid black;
    clear: left;
}
.black {
    float: left;
    margin: 0;
    background-color: black;
    color: #fff;
    width: 20%;
}
.red {
    float: left;
    margin: 0;
    background-color: red;
    width:20%;
}
p {
    width: 50%;
}

clear: right

Contenido HTML

<div class="wrapper">

    <p class="black">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Phasellus sit amet diam. Duis mattis varius dui. Suspendisse eget dolor.</p>

    <p class="red">Lorem ipsum dolor sit amet, consectetuer adipiscing elit.</p>

    <p class="right">This paragraph clears right.</p>

</div>

Contenido CSS

.wrapper{
    border:1px solid black;
    padding:10px;
}
.right {
    border: 1px solid black;
    clear: right;
}
.black {
    float: right;
    margin: 0;
    background-color: black;
    color: #fff;
    width:20%;
}
.red {
    float: right;
    margin: 0;
    background-color: red;
    width:20%;
}
p {
    width: 50%;
}

clear: both

Contenido HTML

<div class="wrapper">

    <p class="black">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Phasellus sit amet diam. Duis mattis varius dui. Suspendisse eget dolor. Fusce pulvinar lacus ac dui.</p>

    <p class="red">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Phasellus sit amet diam. Duis mattis varius dui. Suspendisse eget dolor.</p>

    <p class="both">This paragraph clears both.</p>

</div>

Contenido CSS

.wrapper{
    border:1px solid black;
    padding:10px;
}
.both {
    border: 1px solid black;
    clear: both;
}
.black {
    float: left;
    margin: 0;
    background-color: black;
    color: #fff;
    width:20%;
}
.red {
    float: right;
    margin: 0;
    background-color: red;
    width:20%;
}
p {
    width: 45%;
}

Especificaciones

Specification Status Comment
CSS Logical Properties and Values Level 1
La definici贸n de 'float and clear' en esta especificaci贸n.
Editor's Draft Agrega los valores inline-start y inline-end
CSS Level 2 (Revision 1)
La definici贸n de 'clear' en esta especificaci贸n.
Recommendation Sin cambios significativos, aunque se aclaran los detalles.
CSS Level 1
La definici贸n de 'clear' en esta especificaci贸n.
Recommendation Definici贸n inicial

Compatibilidad del navegador

BCD tables only load in the browser

Tambi茅n puedes ver