CSS 2: Tablas

Posición de la leyenda: caption-side

La propiedad caption-side permite elegir la posición de la leyenda (<caption>) con respecto a la tabla. Los dos valores permitidos son top (arriba) y bottom (abajo). Si no se establece la posición de la leyenda, los navegadores aplican el valor top.

Hueco
caption {
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4
Hueco
caption {
  caption-side: top;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4
Hueco
caption {
  caption-side: bottom;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4

En la recomendación CCS 2 la propiedad caption-side podía tomar también los valores right (derecha) y left (izquierda), pero en la recomendación CSS 2.1 se eliminaron esos valores, que tampoco aparecen en la futura recomendación CSS 3: Tablas, actualmente (septiembre de 2017) en fase de borrador.

Firefox aplica los valores left y right de la propiedad caption-side que Chrome y Edge no aplican. Pero como la recomendación vigente no permite esos valores, se tiene que considerar que Firefox lo está haciendo incorrectamente.

Correcto en Chrome Incorrecto en Firefox Correcto en Edge
caption {
  caption-side: left;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4
Correcto en Chrome Incorrecto en Firefox Correcto en Edge
caption {
  caption-side: right;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4

Centrar una tabla

Para centrar una tabla horizontalmente en la página, se deben establecer las dos propiedades margin-left y margin-right con el valor auto.

table {
  margin-left: auto;
  margin-right: auto;
}
Esto es la leyenda
Celda 1, con más texto Celda 2
Celda 3 Celda 4, con más texto

La alineación del contenido de la leyenda se interpreta dentro del espacio que ocupa la leyenda (que coincide con el ancho de la tabla).

table {
  margin-left: auto;
  margin-right: auto;
}

caption {
  background-color: lightblue;
  text-align: right;
}
Esto es la leyenda
Celda 1, con más texto Celda 2
Celda 3 Celda 4, con más texto

Disposición de la tabla: table-layout

La propiedad table-layout permite elegir el modo en el que el navegador calcula el tamaño total de la tabla y el de cada fila o columna. Los dos valores permitidos son fixed (fijo) y auto (automático).

En el modo fijo (fixed), el tamaño de las tablas y de las celdas depende de las propiedades width y height.

En el modo fijo (auto), el tamaño de las tablas y de las celdas depende de su contenido (y si es posible, de las propiedades width y height).

Por completar con ejemplos

Modos de bordes: border-collapse

La propiedad border-collapse permite elegir el modo de presentación de los bordes de las celdas y de la tabla. Los dos valores permitidos son separate (separado) y collapse (colapsado). En el modo separado existe un hueco entre los bordes de cada celda, mientras que en el modo colapsado los bordes se superponen. Si no se establece el modo de presentación, los navegadores aplican el valor separate.

table {
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4
table {
  border-collapse: separate;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4
table {
  border-collapse: collapse;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4

En la página de bordes, márgenes y fondos en las tablas se explican con detalle estos modos de funcionamiento.

Bordes de celdas vacías: empty-cells

La propiedad empty-cells permite establecer si se muestran o no los bordes de las celdas vacías, en el modo de bordes separado. Los dos valores permitidos son show (mostrar) y hide (ocultar). Si no se establece la propiedad, los navegadores aplican el valor show.

table {
}
Esto es la leyenda
Celda 1
Celda 4
table {
  empty-cells: show;
}
Esto es la leyenda
Celda 1
Celda 4
table {
  empty-cells: hide;
}
Esto es la leyenda
Celda 1
Celda 4

En el modo de bordes colapsado no se aplica la propiedad empty-cells.

table {
  border-collapse: collapse;
  empty-cells: hide;
/* En el modo colapsado empty-cells no hace nada */
}
Esto es la leyenda
Celda A1 Celda A2 Celda A3 Celda A4
Celda B1 Celda B4
Celda C1 Celda C4
Celda D1 Celda D2 Celda D3 Celda D4

Separación entre celdas: border-spacing

La propiedad border-spacing permite establecer una separación entre las celdas cuando se utiliza el modo de bordes separado. Se puede escribir un único valor, que se aplicaría a los cuatro lados, o dos valores, que se aplicarían en horizontal (a derecha e izquierda) y en vertical (arriba y abajo), respectivamente. Los valores no se pueden expresar en porcentajes, pero sí en cualquier otra unidad (px, em, etc).

table {
  border-spacing: 20px;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4
table {
  border-spacing: 30px 10px;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4

Si no se establece la propiedad, los navegadores aplican el valor 2px.

table {
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4
table {
  border-spacing: 2px;
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4

En el modo de bordes colapsado no se aplica la propiedad border-spacing.

table {
  border-collapse: collapse;
  border-spacing: 20px;
/* En el modo colapsado border-spacing no hace nada */
}
Esto es la leyenda
Celda 1 Celda 2
Celda 3 Celda 4