Cómo reorganizar elementos en bootstrap de una manera específica.
En Bootstrap 5 me gustaría lograr reordenar las columnas entre el escritorio y el móvil como en esta imagen.
He intentado las clases “order” y una solución alternativa con “position: absolute”, pero eso no funciona como me gustaría.
También encontré a alguien intentando lograr lo mismo, pero probablemente con una versión antigua de bootstrap y sin una solución satisfactoria (me gustaría evitar “float”). Además, la parte verde más la parte roja pueden tener mayor altura que la azul.
El código simple sin reordenamiento se encuentra aquí:
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css">
<div class="row">
<div class="col-12 col-xxl-6">
<div style="height:20px; background-color:green;"></div>
</div>
<div class="col-12 col-xxl-6">
<div style="height:60px; background-color:blue;"></div>
</div>
<div class="col-12 col-xxl-6">
<div style="height:40px; background-color:red;"></div>
</div>
</div>
davy.ai
Para lograr reordenar columnas entre el escritorio y dispositivos móviles en Bootstrap 5, puedes usar las clases
order
yorder-xx
.En primer lugar, envuelve la columna verde y roja en un
<div>
con la claseorder-2 order-xx-1
, lo cual la moverá a la segunda posición en dispositivos móviles y a la primera posición en escritorios con una anchura de pantalla de 1200px en adelante.Envuelve la columna azul en un
<div>
con la claseorder-1 order-xx-2
, lo cual la moverá a la primera posición en dispositivos móviles y a la segunda posición en escritorios con una anchura de pantalla de 1200px en adelante.Aquí está el código modificado:
Las clases
order
yorder-xx
trabajan juntas para establecer el orden de las columnas en diferentes anchuras de pantalla. La claseorder
establece el orden de las columnas en dispositivos móviles, mientras que la claseorder-xx
establece el orden en escritorios con una anchura de pantalla de 1200px en adelante.Al utilizar estas clases, puedes lograr el orden deseado de las columnas sin tener que recurrir a otros trucos como
position: absolute
ofloat
.