10. Tablas

Hasta que no se empezaron a usar las tablas, la única manera de tabular las cosas era utilizar la etiqueta de preformateado, con la que es necesario poner manualmente los espacios en blanco para que quede todo alineado formando filas y columnas, con un resultado muy poco estético.

Estructura de una tabla

Vamos a ver ordenadamente (de fuera hacia dentro) las etiquetas necesarias para confeccionar las tablas.

1. La etiqueta general, que engloba a todas las demás es <TABLE> y </TABLE>. Es decir:

<TABLE> 
[resto de las etiquetas] 
</TABLE>

Con esto se presentarían los datos tabulados, pero faltaría la característica que hace más atractivas a las tablas, y es que estos datos vayan dentro de unos cajetines formados por un borde. Para esto tenemos que añadir el atributo BORDER a la etiqueta, es decir:

<TABLE BORDER> 
[resto de las etiquetas] 
</TABLE>

2. En el siguiente nivel, dentro de la anterior, están las etiquetas para formar cada fila (row) de la tabla, que son <TR> y </TR>. Hay que repetirlas tantas veces como filas queremos que tenga la tabla. Es decir, para una tabla con dos filas, sería:

<TR> [etiquetas de las distintas celdas de la primera fila] </TR> 
<TR> [etiquetas de las distintas celdas de la segunda fila] </TR>

3. En el último nivel (dentro de las anteriores) están las etiquetas de cada celda, que son <TD> y </TD>, que engloban el contenido de cada celda concreta (texto, imágenes, etc.). Hay que repetirla tantas veces como celdas queremos que haya en esa fila.

Veamos un ejemplo de una tabla con dos filas. Cada fila va a tener tres celdas. Dentro de cada celda vamos a poner un texto indicativo de la posición de dicha celda:

<TABLE BORDER> 
<TR> <TD>fila1-celda1</TD> <TD>fila1-celda2</TD> <TD>fila1-celda3</TD> </TR> 
<TR> <TD>fila2-celda1</TD> <TD>fila2-celda2</TD> <TD>fila2-celda3</TD> </TR> 
</TABLE>

Que resulta:

fila1-celda1 fila1-celda2 fila1-celda3
fila2-celda1 fila2-celda2 fila2-celda3

Filas con desigual número de celdas

En este ejemplo hemos puesto dos filas con igual número de celdas. ¿Qué pasa si ese número es distinto? Pues el navegador forma el número de filas y columnas que haga falta, dejando espacios en blanco en las filas que tengan menos celdas.

Si en el ejemplo anterior eliminamos la tercera celda de la segunda fila, es decir si borramos <TD>fila2-celda3</TD>, resultará:

fila1-celda1 fila1-celda2 fila1-celda3
fila2-celda1 fila2-celda2  

Titular de la tabla

Se puede añadir un titular (caption) a la tabla, es decir un texto situado encima de la tabla que indica cuál es su contenido. Se consigue con la etiqueta <CAPTION> y </CAPTION>.

Si en el ejemplo anterior añadimos la siguiente línea:

<CAPTION> Ejemplo de filas desiguales </CAPTION>, resulta:

  Ejemplo de filas desiguales
fila1-celda1 fila1-celda2 fila1-celda3
fila2-celda1 fila2-celda2  

Variando el espesor de los bordes

El atributo BORDER (visto más arriba) pone por defecto un borde de espesor igual a la unidad. Pero se puede hacer que este borde sea tan grueso como queramos, poniendo:

<TABLE BORDER=número deseado>

Si en el ejemplo anterior ponemos: <TABLE BORDER=5>

  Ejemplo de filas desiguales
fila1-celda1 fila1-celda2 fila1-celda3
fila2-celda1 fila2-celda2  

Celdas de cabecera

Además de las celdas que contienen datos normales, podemos poner, si nos conviene, celdas de cabecera (header), que se distinguen por estar el texto de dichas celdas en negrita y centrado.

Esto se consigue con la etiqueta <TH> y </TH> (en vez de la normal <TD> y </TD>)

Vamos a añadir, en el ejemplo anterior, una fila de estas celdas de cabecera, antes de las otras dos que ya existían:

<TR> <TH>Columna 1</TH> 
<TH>Columna 2</TH> 
<TH>Columna 3</TH> </TR>

Que resulta: 

  Ejemplo de filas desiguales
Columna 1Columna 2Columna 3
fila1-celda1 fila1-celda2 fila1-celda3
fila2-celda1 fila2-celda2  

Se pueden colocar en el sitio que se quiera, aunque lo normal es que vayan en los bordes., encabezando las columnas o las filas.

Contenido de las celdas

Hasta ahora, en todos los ejemplos se ha puesto un texto normal dentro de las distintas celdas. Pero se puede poner en ellas cualquier otro elemento de los que van en un documento HTML, como imágenes, enlaces, etc. No hay más que poner dentro de la etiqueta de la celda la etiqueta correspondiente a una imagen, un enlace, etc.

Ejemplo con una imagen:

<TABLE BORDER=2> 
<TR>
<TD><IMG SRC="babe.gif"></TD>
</TR> 
</TABLE>

Ejemplo con un enlace:

<TABLE BORDER=2> 
<TR>
<TD><A HREF="index.html">Página principal </A></TD>
</TR> 
</TABLE>

Página principal

Posicionamiento del contenido dentro de la celda

Normalmente, el contenido de una celda está alineado a la izquierda. Pero se puede cambiar esto añadiendo dentro de la etiqueta de la celda los siguientes atributos:

<TD ALIGN=CENTER> Al centro </TD> 
<TD ALIGN=RIGHT> A la derecha </TD> 
<TH ALIGN=LEFT> Cabecera a la izquierda </TH> 
(Recuérdese que por defecto están centradas)

Ejemplos de alineamiento horizontal dentro de la celda

Al centro

A la derecha

Cabecera a la izquierda

El alineamiento por defecto en el sentido vertical es en el medio. También se puede cambiar, añadiendo dentro de la etiqueta de la celda los siguientes atibutos:

<TD VALIGN=TOP> Arriba </TD> 
<TD VALIGN=BOTTOM> Abajo </TD>

Arriba  Abajo

Variando las dimensiones de la tabla

El navegador se encarga normalmente de dimensionar el tamaño total de la tabla de acuerdo con el número de filas, de columnas, por el contenido de las celdas, espesor de los bordes, etc.

A veces nos puede convenir forzarle para que la tabla tenga unas dimensiones totales mayores que las que le corresponden, tanto en anchura como en longitud. Esto se consigue añadiendo dentro de la etiqueta de la tabla los atributos WIDTH y HEIGHT igual a un porcentaje de la dimensión de la pantalla, o a una cifra que equivale al número de pixels.

Por ejemplo, si ponemos:

<TABLE WIDTH=60%>

Arriba  Abajo

O, si ponemos:

<TABLE HEIGHT=200>

Arriba  Abajo

Celdas que abarcan a otras varias

A veces puede interesarnos que una celda se extienda sobre otras varias. Esto se consigue añadiéndo dentro de la etiqueta de la celda los atributos COLSPAN=número para extenderse sobre un número determinado de columnas, o ROWSPAN=número para extenderse verticalmente sobre un número determinado de filas.

Por ejemplo, en la primera tabla de este capítulo vamos a añadir una fila con una sola celda, que abarca a dos columnas:

<TR> <TD COLSPAN=2> Celda sobre 2 columnas </TD> <TR>

Celda sobre 2 columnas

fila1-celda1 fila1-celda2 fila1-celda3 
fila2-celda1 fila2-celda2 fila2-celda3

O, en la misma tabla, vamos a añadir una celda en la primera fila. pero que abarque también a la siguiente:

<TD ROWSPAN=2> Celda junto a 2 filas </TD>

Celda junto a 2 filas fila1-celda1 fila1-celda2 fila1-celda3 
fila2-celda1 fila2-celda2 fila2-celda3

Color de fondo en las tablas

Podemos conseguir que las tablas tengan un color de fondo, siguiendo un procedimiento totalmente análogo al empleado para que una página tenga un color de fondo uniforme (según vimos en el capítulo 7). Para ello debemos utilizar el atributo BGCOLOR="#XXYYZZ", visto en dicho capítulo.

Se puede conseguir:

1. Que la totalidad de la tabla tenga un color de fondo. Para ello, colocamos el atributo dentro de la etiqueta TABLE. Por ejemplo, vamos a hacer que la tabla tenga un fondo verde (#00FF00):

<TABLE BORDER BGCOLOR="#00FF00"> 
<TR> 
<TD>fila1-celda1</TD> <TD>fila1-celda2</TD> 
</TR> 
<TR> 
<TD>fila2-celda1</TD> <TD>fila2-celda2</TD> 
</TR> 
</TABLE>

Que resulta:

fila1-celda1

fila1-celda2
fila2-celda1 fila2-celda2

2. Que solamente una celda determinada tenga un color de fondo. Para ello, colocamos el atributo dentro de la etiqueta de la celda correspondiente. Por ejemplo, vamos a hacer que sólo la celda 1 de la fila 1 tenga un color verde:

<TABLE BORDER> 
<TR>
<TD BGCOLOR="#00FF00">fila1-celda1</TD><TD>fila1-celda2</TD>
</TR> 
<TR> 
<TD>fila2-celda1</TD> <TD>fila2-celda2</TD> 
</TR> 
</TABLE>

Que resulta:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

3.Que la generalidad de las celdas tenga un color, pero que alguna celda tenga uno particular. El atributo del color general se coloca en la etiqueta TABLE, y el del color particular en la etiqueta de la celda en cuestión (una combinación de los dos casos anteriores). por ejemplo, vamos a hacer que la generalidad de la tabla sea de color rojo (#FF0000), pero que la celda 1 de la fila 1 sea de color verde (#00FF00):

<TABLE BORDER BGCOLOR="#FF0000"> 
<TR>
<TD BGCOLOR="#00FF00">fila1-celda1</TD><TD>fila1-celda2</TD>
</TR> 
<TR> 
<TD>fila2-celda1</TD> <TD>fila2-celda2</TD> 
</TR> 
</TABLE>

Que resulta:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

Imágenes de fondo en las tablas

El Explorer de Microsoft soporta la colocación de imágenes de fondo en el interior de las tablas, de una manera análoga a como se hace en una página (según vimos en el capítulo 7). Para ello debemos utilizar el atributo BACKGROUND="imagen.gif" o BACKGROUND="imagen.jpg", visto en dicho capítulo.

Si se utiliza dentro de la etiqueta <TABLE> la imagen en cuestión se multiplicará detrás de todas las celdas.

Por ejemplo, si ponemos:

<TABLE BORDER BACKGROUND="nubes.jpg"> 
(Se omite el resto de las etiquetas de la tabla)

Obtenemos:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

(Con el Netscape no se verá ninguna imagen de fondo, sólo con el Explorer)

Si, por el contrario, sólo se pone este atributo dentro de la etiqueta de una celda concreta (<TD> o <TH>), entonces la imagen de fondo se verá sólo en esa celda, como por ejemplo:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

Separación entre las celdas de una tabla

Por defecto, la separación entre las distintas celdas de una tabla es de dos pixels. Pero se puede variar esto con el atributo CELLSPACING, que se pone dentro de la etiqueta TABLE.

Por ejemplo, para obtener una separación de 20 pixels entre celdas ponemos:

<TABLE BORDER CELLSPACING=20> 
(Se omite el resto de las etiquetas de la tabla)

Con lo que se obtiene:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

A primera vista parece como si esto fuera lo mismo que si hubiéramos aumentado el espesor de los bordes. Pero para comprobar que no es así, hagamos que en el caso anterior, tenga además unos bordes de 5 de espesor:

<TABLE BORDER=5 CELLSPACING=20>

Con lo que se obtiene:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

Separación entre el borde y el contenido dentro de las celdas

Por defecto, la separación entre el borde y el contenido dentro de las celdas es de un pixel. Se puede cambiar esto con el atributo CELLPADDING, que se pone dentro de la etiqueta TABLE.

Por ejemplo, para obtener una separación de 20 pixels entre el contenido y los bordes, dentro de cada celda:

<TABLE BORDER CELLPADDING=20> 
(Se omite el resto de las etiquetas de la tabla)

Con lo que se obtiene:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

Se puede combinar este atributo con CELLSPACING (visto en el apartado anterior).

Por ejemplo, una tabla con bordes de 5 de espesor, separación entre celdas de 15 y separación del contenido con respecto a los bordes de las celdas de 20, lo obtendríamos con:

<TABLE BORDER=5 CELLSPACING=15 CELLPADDING=20> 
(Se omite el resto de las etiquetas de la tabla)

Con lo que se obtiene:

fila1-celda1 fila1-celda2
fila2-celda1 fila2-celda2

Ejemplo práctico

Partiendo del ejemplo práctico del capítulo anterior, mipag9.html, vamos a crear una tabla de dos filas, con una celda cada una. La primera, como cabecera, con el texto "Un lugar ideal para mis vacaciones", y la segunda con la imagen isla.gif. Además vamos a alargar a lo ancho la tabla al 75% de la pantalla.

Para ello sustituimos:

<H3> Un lugar ideal para mis vacaciones </H3> 
<IMG SRC="isla.gif" ALT="isla">

Por lo siguiente:

<P> 
<TABLE BORDER=5 WIDTH=75%> 
<TR> <TH> Un lugar ideal para mis vacaciones </TH> 
</TR> 
<TR> 
<TD> <IMG SRC="isla.gif" ALT="isla"> </TD> 
</TR> 
</TABLE>

Guardamos este fichero como mipag10.html y lo cargamos en el navegador para verlo. Resultado.


WebMaestro: http://wmaestro.com/webmaestro - © Francisco Arocena