css flexbox bootstrap-4 css-multicolumn-layout

css - Diseño de mampostería Bootstrap 4 utilizando cuadrícula flexbox



bootstrap-4 css-multicolumn-layout (1)

¿Hay alguna manera de crear un diseño de columna de mampostería utilizando la cuadrícula de flexbox con la que Bootstrap 4 viene equipado? Me parece que todas las columnas tienen la misma altura.


Esto es bastante factible con las clases estándar de Bootstrap 4. Incluso hay una sección completa en la documentación sobre la función de columnas de la Tarjeta .

De los documentos:
Las tarjetas se pueden organizar en columnas similares a la Masonry con solo CSS envolviéndolas en .card-columns . Las tarjetas están construidas con propiedades de columna CSS en lugar de flexbox para una alineación más fácil. Las tarjetas se ordenan de arriba a abajo y de izquierda a derecha.

¡Aviso! Su millaje con columnas de tarjetas puede variar. Para evitar que las tarjetas se rompan en las columnas, debemos configurarlas para que display: inline-block como column-break-inside: avoid todavía no es una solución a prueba de balas.

Entonces, todo lo que tienes que hacer es envolver tus .card s en un .card-columns como este:

<div class="container"> <div class="card-columns"> <div class="card"> <img class="card-img-top" src="http://via.placeholder.com/1600x900/483D8B/ffffff?text=Card+1" alt="Card image cap"> <div class="card-body"> <h5 class="card-title">Card title that wraps to a new line</h5> <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p> </div> </div> <div class="card p-3"> <blockquote class="blockquote mb-0 card-body"> <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Integer posuere erat a ante.</p> <footer class="blockquote-footer"> <small class="text-muted"> Someone famous in <cite title="Source Title">Source Title</cite> </small> </footer> </blockquote> </div> <div class="card"> <img class="card-img-top" src="http://via.placeholder.com/1600x450/9400D3/ffffff?text=Card+2" alt="Card image cap"> <div class="card-body"> <h5 class="card-title">Card title</h5> <p class="card-text">This card has supporting text below as a natural lead-in to additional content.</p> <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p> </div> </div> <div class="card bg-primary text-white text-center p-3"> <blockquote class="blockquote mb-0"> <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Integer posuere erat.</p> <footer class="blockquote-footer"> <small> Someone famous in <cite title="Source Title">Source Title</cite> </small> </footer> </blockquote> </div> <div class="card text-center"> <div class="card-body"> <h5 class="card-title">Card title</h5> <p class="card-text">This card has supporting text below as a natural lead-in to additional content.</p> <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p> </div> </div> <div class="card"> <img class="card-img" src="http://via.placeholder.com/1600x1600/FF1493/ffffff?text=Card+3" alt="Card image"> </div> <div class="card p-3 text-right"> <blockquote class="blockquote mb-0"> <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Integer posuere erat a ante.</p> <footer class="blockquote-footer"> <small class="text-muted"> Someone famous in <cite title="Source Title">Source Title</cite> </small> </footer> </blockquote> </div> <div class="card"> <div class="card-body"> <h5 class="card-title">Card title</h5> <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This card has even longer content than the first to show that equal height action.</p> <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p> </div> </div> </div> </div> <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" rel="stylesheet"/>