Volver al índiceBordes

Cualquier elemento de una página web puede tener un borde (en inglés, border).

En esta página se tratan los siguientes temas:


La propiedad compuesta border

La propiedad compuesta border permite establecer simultáneamente los cuatro bordes (arriba, derecha, abajo e izquierda) de un elemento, definiendo su:

Las tres características del borde se pueden escribir en cualquier orden.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px solid; 
}

Esto es un párrafo con borde de estilo solid.

Volver al principio de la página


Estilos de bordes

Los estilos de bordes definidos en CSS2 son none, hidden, dotted, dashed, solid, double, groove, ridge, inset y outset.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px none; 
}

Esto es un párrafo con borde de estilo none.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px hidden; 
}

Esto es un párrafo con borde de estilo hidden.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px dotted; 
}

Esto es un párrafo con borde de estilo dotted.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px dashed; 
}

Esto es un párrafo con borde de estilo dashed.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px solid; 
}

Esto es un párrafo con borde de estilo solid.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px double; 
}

Esto es un párrafo con borde de estilo double.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px groove; 
}

Esto es un párrafo con borde de estilo groove.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px ridge; 
}

Esto es un párrafo con borde de estilo ridge.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px inset; 
}

Esto es un párrafo con borde de estilo inset.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: red 5px outset; 
}

Esto es un párrafo con borde de estilo outset.


Los estilos groove, ridge inset y outset producen un efecto tridimensional, pero el resultado depende del color del borde y de los colores de fondo del elemento y del elemento superior:

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: white 8px groove; 
}

Esto es un párrafo con borde de estilo groove.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: white 8px ridge; 
}

Esto es un párrafo con borde de estilo ridge.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: white 8px inset; 
}

Esto es un párrafo con borde de estilo inset.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border: white 8px outset; 
}

Esto es un párrafo con borde de estilo outset.


Los estilos none y hidden producen el mismo resultado (no se muestra el borde), salvo en el caso de las tablas en modo colapsado, en el que hidden oculta el borde independientemente del borde de la casilla contigua, pero none no (para que se oculte el borde común, las dos casillas contiguas deben tener su borde común en none).

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
table { 
  border-collapse: collapse;
}
td.sinborde {
  border: hidden
}
Celda A1 Celda A2 Celda A3
Celda B1 Celda B2
(sin borde)
Celda B3
(sin borde)
Celda C1 Celda C2 Celda C3
Celda A1 Celda A2 Celda A3
Celda B1 Celda B2
(sin borde)
Celda B3
(sin borde)
Celda C1 Celda C2 Celda C3
Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
table { 
  border-collapse: collapse;
}
td.sinborde {
  border: none
}
Celda A1 Celda A2 Celda A3
Celda B1 Celda B2
(sin borde)
Celda B3
(sin borde)
Celda C1 Celda C2 Celda C3
Celda A1 Celda A2 Celda A3
Celda B1 Celda B2
(sin borde)
Celda B3
(sin borde)
Celda C1 Celda C2 Celda C3

Nota: Versiones anteriores a Firefox 7 no se comportaban de este modo, como se comenta en la página de diferencias entre versiones de Firefox.

Volver al principio de la página


Las propiedades compuestas border-top, border-right, border-bottom y border-left

Las propiedades compuestas border-top, border-right, border-bottom y border-left permiten establecer de forma independiente los cuatro bordes (arriba, derecha, abajo e izquierda, respectivamente) de un elemento, definiendo su color, su grosor y su estilo. Se pueden escribir las tres características de cada borde en cualquier orden. Se puede definir uno, dos, tres o cuatro bordes.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-left: red 5px solid; 
}

Esto es un párrafo con borde izquierdo.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-top: black 5px dashed;
  border-left: red 5px solid; }

Esto es un párrafo con borde izquierdo y superior.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-top: black 5px dashed;
  border-bottom: blue 10px dotted;
  border-left: red 5px solid; }

Esto es un párrafo con borde izquierdo, superior e inferior.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-top: black 5px dashed;
  border-right: green 10px double;
  border-bottom: blue 10px dotted;
  border-left: red 5px solid; }

Esto es un párrafo con cuatro bordes distintos.

Volver al principio de la página


Las propiedades border-color, border-width y border-style

Las propiedades border-color, border-width y border-style permiten establecer, respectivamente, el color, el grosor y el estilo de los cuatro bordes de un elemento. A cada una de las propiedades se le puedes dar uno, dos, tres o cuatro valores, que se interpretan de la siguiente manera:

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-color: red;
  border-width: 10px;
  border-style: solid; }

Esto es un párrafo con borde.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-color: red black;
  border-width: 10px;
  border-style: solid; }

Esto es un párrafo con borde.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-color: red black green;
  border-width: 10px;
  border-style: solid; }

Esto es un párrafo con borde.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-color: red black green orange;
  border-width: 10px;
  border-style: solid; }

Esto es un párrafo con borde.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-color: red black green;
  border-width: 10px 40px;
  border-style: dashed solid dotted; }

Esto es un párrafo con borde.


En general, para que el navegador muestre un borde, se tendrían que definir las tres propiedades (color, grosor y estilo), pero en realidad se puede comprobar que con sólo definir el estilo ya se muestra un borde negro. El motivo es que la hoja de estilo predeterminada de los navegadores define un color y un grosor por omisión y al definir el estilo se completa la definición del borde.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-style: solid;
}

Esto es un párrafo con borde.

Si no define el estilo del borde, aunque se defina el color y el grosor los navegadores no muestran el borde.

Correcto en Firefox Correcto en Internet Explorer Correcto en Chrome
p { 
  border-color: red;
  border-width: 5px;
}

Esto es un párrafo con borde.

Volver al principio de la página


Las propiedades individuales

Se puede establecer de forma independiente cada propiedad de cada borde mediante las propiedades:

En general, para que el navegador muestre un borde, se tienen que definir las tres propiedades (color, grosor y estilo), aunque normalmente los navegadores asignan el color negro como color prederminado, por lo que si no se establece el color del borde suele mostrarse de color negro

Volver al principio de la página


Bordes en <html> y <body>

Las etiquetas <html> y <body> también pueden tener bordes, como muestra la siguiente página de ejemplo.

El borde de <body> se adapta al contenido, sin tener en cuenta los elementos flotantes, mientras que el borde de <html> abarca los elementos flotantes, como muestra la siguiente página de ejemplo.

En el ejemplo anterior hay una diferencia entre Firefox y Chrome e Internet Explorer, como muestran las dos capturas siguientes:

Correcto en Firefox Correcto en Chrome Ejemplo de imagen con float y margin de html en Firefox
Incorrecto en Internet Explorer Ejemplo de tamaño de fuente. Texto normal en Internet Explorer 8

Nota: Internet Explorer 7 representa correctamente el borde de <html> y <body>. Las versiones anteriores lo hacían incorrectamente, como se comenta en la página de diferencias entre IE7 e IE6.

Volver al principio de la página

Esta página forma parte del curso "Páginas web HTML / XHTML y hojas de estilo CSS" disponible en http://www.mclibre.org
Autor: Bartolomé Sintes Marco
Última modificación: 21 de diciembre de 2011

Creative Commons License
Esta obra está bajo una licencia de Creative Commons Reconocimiento-CompartirIgual 3.0 España.