Curso gratuito de HTML. Regístrate para hacer un seguimiento de tu progreso →

HTML: Tablas

Una de las formas más comunes de presentar información es mediante tablas. Las encontramos en todas partes: información sobre productos, tablas de multiplicar, documentos. Esta presentación permite comparar fácilmente las características de diferentes productos. Al diseñar páginas, las tablas se utilizan con frecuencia, aunque su estructura puede ser un poco compleja.

Una tabla es un elemento compuesto que se crea a partir de varios tags anidados entre sí. Es similar a cómo se construyen las listas, con un contenedor y tags especiales para los elementos.

La estructura de una tabla consta de varios elementos principales:

  • <table> — área de la tabla
    • <tr> — fila
    • <thead> — encabezado de la tabla
    • <th> — celda de encabezado
    • <tbody> — cuerpo de la tabla
    • <td> — celda

Cualquier tabla comienza con la etiqueta de apertura <table>

<table>
  <!-- Aquí estarán los datos de la tabla -->
</table>

Es dentro de esta etiqueta que se crean las filas y las columnas de la tabla. Ahora puedes crear filas y columnas. Para hacerlo, utiliza las etiquetas <tr> y <td>. Creemos dos filas con tres celdas en cada una:

<table>
  <tr> <!-- Fila -->
    <td>Chocolate "Totá"</td> <!-- Celda -->
    <td>100 gramos</td>
    <td>2 dólares</td>
  </tr>

  <tr> <!-- Fila -->
    <td>Chocolate "Totá TeamLead"</td> <!-- Celda -->
    <td>100 gramos</td>
    <td>5 dólares</td>
  </tr>
</table>
Chocolate "Totá" 100 gramos 2 dólares
Chocolate "Totá TeamLead" 100 gramos 5 dólares

Importante: El número de celdas en cada fila debe ser el mismo.


Intenta copiar este código en el editor. Observa que la presentación visual será diferente a la de la teoría de esta lección. Esto se debe a que, por defecto, los navegadores no muestran bordes visibles para las celdas de la tabla. Para lograrlo, necesitas usar CSS, un lenguaje de estilos especial. Podrás encontrar este lenguaje y sus capacidades en otro curso.

Los datos ya están presentados, pero faltan encabezados para describir cada columna. Para crear encabezados en la tabla, utiliza la etiqueta <thead> y, como celda, la etiqueta <th>. Por lo demás, la estructura de marcado no cambia. Complementemos la tabla con encabezados:

<table>
  <thead> <!-- Encabezado de la tabla -->
    <tr>
      <th>Delicia</th> <!-- Celda de encabezado -->
      <th>Peso</th>
      <th>Precio</th>
    </tr>
  </thead>

  <tr>
    <td>Chocolate "Totá"</td>
    <td>100 gramos</td>
    <td>2 dólares</td>
  </tr>

  <tr>
    <td>Chocolate "Totá TeamLead"</td>
    <td>150 gramos</td>
    <td>5 dólares</td>
  </tr>
</table>
Delicia Peso Precio
Chocolate "Totá" 100 gramos 2 dólares
Chocolate "Totá TeamLead" 150 gramos 5 dólares

El último paso es agregar la etiqueta <tbody>, que marca la parte principal de la tabla. A menudo los desarrolladores omiten esta etiqueta, ya que los navegadores envuelven automáticamente un grupo de filas que no están dentro de otras etiquetas. Ten en cuenta que la etiqueta <tbody> suele usarse solo una vez en una tabla. En tablas más grandes, se pueden usar múltiples <tbody> para separar diferentes secciones de la tabla, pero en la mayoría de los casos esto no es necesario.

<table>
  <thead>
    <tr>
      <th>Delicia</th>
      <th>Peso</th>
      <th>Precio</th>
    </tr>
  </thead>

  <tbody> <!-- Cuerpo de la tabla -->
    <tr>
      <td>Chocolate "Totá"</td>
      <td>100 gramos</td>
      <td>2 dólares</td>
    </tr>

    <tr>
      <td>Chocolate "Totá TeamLead"</td>
      <td>150 gramos</td>
      <td>2 dólares</td>
    </tr>
  </tbody>
</table>

Además, se puede agregar un "footer" a la tabla. Aquí se puede incluir información resumida, como el costo total de los productos.

Puedes personalizar el título de la tabla. Esto es útil cuando se muestran varias tablas al mismo tiempo. Ayuda a distinguirlas entre sí y a no confundirse acerca de qué tabla está mostrando qué información. Para crear un título en la tabla, utiliza la etiqueta <caption>. Si hay un título, debe ubicarse inmediatamente después de la etiqueta <table>. Agreguemos un título a la tabla:

<table>
  <caption>Asortimento de Chocolate "Hexlet"</caption>
  <thead>
    <tr>
      <th>Delicia</th>
      <th>Peso</th>
      <th>Precio</th>
    </tr>
  </thead>

  <tbody>
    <tr>
      <td>Chocolate "Totá"</td>
      <td>100 gramos</td>
      <td>2 dólares</td>
    </tr>

    <tr>
      <td>Chocolate "Totá TeamLead"</td>
      <td>150 gramos</td>
      <td>2 dólares</td>
    </tr>
  </tbody>
</table>
Asortimento de Chocolate "Hexlet"
Delicia Peso Precio
Chocolate "Totá" 100 gramos 2 dólares
Chocolate "Totá TeamLead" 150 gramos 5 dólares

Tarea

Crea una tabla con 3 filas y 2 celdas en cada una. La primera fila debe contener el encabezado de la tabla.

¿El ejercicio no pasa la prueba, qué debo hacer? 😶

Si te quedaste atascado, es el momento perfecto para hacer una pregunta en las "Discusiones".
* Asegúrate de incluir la salida de las pruebas. Sin ella, es casi imposible entender qué está mal, incluso si muestras tu código. Los programadores tienen dificultades para ejecutar el código en su mente, pero casi siempre es posible entender a dónde mirar a partir del error que recibiste.

Mi código funciona en mi entorno, pero no aquí 🤨

Las pruebas están diseñadas de manera que verifican la solución de diferentes maneras y con diferentes datos. A menudo, una solución funciona con ciertos datos de entrada pero no con otros. Para entender este punto, revisa la pestaña "Pruebas" y presta atención a los mensajes de error, que suelen contener pistas.

Mi código es diferente a la solución del profesor 🤔

Esto es normal 🙆. En programación, una tarea puede tener muchas soluciones diferentes. Si tu código pasa la prueba, cumple con los requisitos de la tarea.

En raras ocasiones, la solución puede estar ajustada para pasar las pruebas, pero esto suele ser evidente.

Leí la lección, pero no entendí nada 🙄

Crear materiales de aprendizaje comprensibles para todos es bastante difícil. Hacemos nuestro mejor esfuerzo, pero siempre hay margen para mejorar. Si encuentras material que no entiendes, describe el problema en las "Discusiones". Es ideal si puedes formular los aspectos que no entiendes en forma de preguntas. Por lo general, necesitamos unos días para hacer mejoras.

Por cierto, tú también puedes contribuir a mejorar los cursos: en la parte inferior hay un enlace al código fuente de las lecciones, que se puede modificar directamente en el navegador.

Consejos útiles

  • El número de celdas en cada fila debe ser el mismo.

  • El título de la tabla (caption) siempre debe ir después de la etiqueta de apertura de la tabla (<table>).

  • Los navegadores automáticamente agregan la etiqueta <tbody> si está ausente. En tablas pequeñas, puedes omitir su uso.


¿Encontraste un error? ¿Quieres añadir algo? Las solicitudes de extracción son bienvenidas. https://codica.la/errores
Si te encuentras con dificultades y no sabes qué hacer, pregunta en nuestra gran y amigable comunidad