CSS: Bordes (1)

En esta lección y en la lección CSS Bordes (2) se comentan las propiedades CSS definidas en la futura recomendación CSS Backgrounds and Borders Module Level 3. Aunque actualmente (marzo de 2023) esta recomendación no está formalmente aprobada, se considera parte de la definición oficial de CSS en CSS Snapshot 2023.

Estas propiedades permiten añadir un borde a cualquier elemento elemento de una página web.

En esta lección se comentan principalmente las propiedades "clásicas", que ya estaban incluidas en CSS 2, publicada en mayo de 1998.

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.

p {
  border: red 5px solid;
}
Enlace externo

Estilos de bordes

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

p {
  border: red 5px none;
}
Enlace externo
p {
  border: red 5px hidden;
}
Enlace externo
p {
  border: red 5px dotted;
}
Enlace externo
p {
  border: red 5px dashed;
}
Enlace externo
p {
  border: red 5px solid;
}
Enlace externo
p {
  border: red 5px double;
}
Enlace externo
p {
  border: red 5px groove;
}
Enlace externo
p {
  border: red 5px ridge;
}
Enlace externo
p {
  border: red 5px inset;
}
Enlace externo
p {
  border: red 5px outset;
}
Enlace externo

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:

p {
  border: white 8px groove;
}
Enlace externo
p {
  border: white 8px ridge;
}
Enlace externo
p {
  border: white 8px inset;
}
Enlace externo
p {
  border: white 8px outset;
}
Enlace externo

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).

table {
  border-collapse: collapse;
}

td.sinborde {
  border: hidden
}
Enlace externo
table {
  border-collapse: collapse;
}

td.sinborde {
  border: none
}
Enlace externo

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.

Propiedades border-top, border-right, border-bottom y border-left En el modelo de caja CSS, cualquier elemento (texto, imagen, etc.) está metido dentro de una caja rectangular que puede tener borde, margen interior y margen exterior. border-top border-right border-bottom border-left

p {
  border-left: red 5px solid;
}
Enlace externo
p {
  border-top: black 5px dashed;
  border-left: red 5px solid;
}
Enlace externo
p {
  border-top: black 5px dashed;
  border-bottom: blue 10px dotted;
  border-left: red 5px solid;
}
Enlace externo
p {
  border-top: black 5px dashed;
  border-right: green 10px double;
  border-bottom: blue 10px dotted;
  border-left: red 5px solid;
}
Enlace externo

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:

Propiedad border-color con 1 valor En el modelo de caja CSS, cualquier elemento (texto, imagen, etc.) está metido dentro de una caja rectangular que puede tener borde, margen interior y margen exterior. border-color: red 1 1 1 1 1 Propiedad border-color con 2 valores En el modelo de caja CSS, cualquier elemento (texto, imagen, etc.) está metido dentro de una caja rectangular que puede tener borde, margen interior y margen exterior. border-color: red   blue 1 2 1 2 1 2

Propiedad border-color con 3 valores En el modelo de caja CSS, cualquier elemento (texto, imagen, etc.) está metido dentro de una caja rectangular que puede tener borde, margen interior y margen exterior. border-color: red   blue   yellow 1 2 3 1 2 3 2 Propiedad border-color con 4 valores En el modelo de caja CSS, cualquier elemento (texto, imagen, etc.) está metido dentro de una caja rectangular que puede tener borde, margen interior y margen exterior. border-color: red   blue   yellow   green 1 2 3 4 1 2 3 4

p {
  border-color: red;
  border-width: 10px;
  border-style: solid;
}
Enlace externo
p {
  border-color: red black;
  border-width: 10px;
  border-style: solid;
}
Enlace externo
p {
  border-color: red black green;
  border-width: 10px;
  border-style: solid;
}
Enlace externo
p {
  border-color: red black green orange;
  border-width: 10px;
  border-style: solid;
}
Enlace externo
p {
  border-color: red black green;
  border-width: 10px 40px;
  border-style: dashed solid dotted;
}
Enlace externo

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.

p {
  border-style: solid;
}
Enlace externo

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

p {
  border-color: red;
  border-width: 5px;
}
Enlace externo

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

Bordes redondeados: border-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius y border-top-left-radius

Estas propiedades permiten definir bordes con esquinas redondeadas:

blockquote {
  padding: 3px 10px;
  border: PowderBlue 5px solid;
  border-radius: 20px;
}
Enlace externo
blockquote {
  padding: 3px 10px;
  border: PowderBlue 5px solid;
  border-top-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
Enlace externo
blockquote {
  padding: 3px 10px;
  border: PowderBlue 5px double;
  border-top-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
Enlace externo
blockquote {
  padding: 3px 10px;
  border: PowderBlue 5px dashed;
  border-top-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
Enlace externo

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.