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

HTML: Unir celdas dentro de filas y columnas

A menudo es necesario unir filas o columnas en tablas. Esto ayuda a combinar información diversa. Por ejemplo, si un producto no está disponible en una tabla de inventario, no tiene sentido duplicar constantemente la información, se puede unir y escribir que el producto no está en el inventario:

Producto Precio Cantidad
No disponible en el inventario

En HTML, se pueden unir celdas en columnas o filas utilizando los atributos especiales colspan y rowspan. Sus valores son la cantidad de celdas a la derecha (para colspan) o debajo (para rowspan) que se deben unir con la celda actual. La cuenta comienza desde la celda actual a la que se aplica la propiedad. Por ejemplo, si se establece el valor colspan="2", la celda actual se unirá con la celda adyacente.

La marcación para el ejemplo anterior sin tener en cuenta la unión de celdas sería la siguiente:

<table>
  <thead>
    <tr>
      <th>Producto</th>
      <th>Precio</th>
      <th>Cantidad</th>
    </tr>
  </thead>

  <tbody>
    <tr>
      <td>Té</td>
      <td>No disponible en el inventario</td> <!-- celda que queremos unir -->
      <td></td>
    </tr>
  </tbody>
</table>

Para unir celdas, debes realizar dos acciones:
1. Agregar el atributo colspan con el valor igual a la cantidad de celdas a la derecha que se van a unir a la etiqueta de la celda que se va a unir.
2. Eliminar las celdas adicionales de la fila.

<table>
  <thead>
    <tr>
      <th>Producto</th>
      <th>Precio</th>
      <th>Cantidad</th>
    </tr>
  </thead>

  <tbody>
    <tr>
      <td>Té</td>
      <td colspan="2">No disponible en el inventario</td>
    </tr>
  </tbody>
</table>

Para unir celdas verticalmente, se utiliza el atributo rowspan. El algoritmo de acciones es similar al de la unión horizontal. La única diferencia es que se deben eliminar las celdas en las filas adyacentes:

<table>
  <thead>
    <tr>
      <th>Empleado</th>
      <th>Salario</th>
      <th>Bonificaciones</th>
      <th>Gerente</th>
    </tr>
  </thead>

  <tbody>
    <tr>
      <td>Alex Hernández</td>
      <td>750$</td>
      <td>63$</td>
      <td rowspan="2">Luis Castillo</td>
    </tr>
    <tr>
      <td>Víctor López</td>
      <td>1200$</td>
      <td>0</td>
    </tr>
  </tbody>
</table>

En el ejemplo, dos empleados interactúan con un mismo gerente. Se podría indicar su nombre dos veces, pero es más claro unir las celdas verticalmente. Para ello, se agregó el atributo rowspan="2", y en la segunda fila se eliminó la cuarta celda, ya que será ocupada por la celda de arriba.

Empleado Salario Bonificaciones Gerente
Alex Hernández 750$ 63$ Luis Castillo
Víctor López 1200$ 0

Tarea

Crea una tabla con dos filas y tres columnas. En la segunda fila, une las dos primeras celdas utilizando atributos. La primera fila debe ser 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 de la tabla debe ser el mismo después de la unión. Es importante distinguir entre el número de etiquetas <td> y el número total de celdas. Por ejemplo, al usar el atributo colspan="2", obtendrás dos celdas lógicas, pero estarán unidas. Por esta razón, es necesario eliminar una celda física de la marcación para compensar.

  • Si se utiliza el atributo colspan, se deben eliminar las celdas en la misma fila del HTML. Si se utiliza el atributo rowspan, se deben eliminar las celdas en las filas inferiores.


¿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