web-dev-qa-db-fra.com

Comment créer des colonnes Bootstrap de la même hauteur?

J'utilise Bootstrap. Comment puis-je faire trois colonnes de la même hauteur?

Voici une capture d'écran du problème. Je voudrais que les colonnes bleues et rouges aient la même hauteur que la colonne jaune. 

Three bootstrap columns with the center column longer than the other two columns

Voici le code: 

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>
<div class="container-fluid">
<div class="row">
    <div class="col-xs-4 panel" style="background-color: red">
        some content
    </div>
    <div class="col-xs-4 panel" style="background-color: yellow">
        catz
        <img width="100" height="100" src="https://lorempixel.com/100/100/cats/">
    </div>
    <div class="col-xs-4 panel" style="background-color: blue">
        some more content
    </div>
</div>
</div>

836
Richard

Solution 1 utilisant des marges négatives (ne rompt pas la réactivité) 

Démo

.row{
    overflow: hidden; 
}

[class*="col-"]{
    margin-bottom: -99999px;
    padding-bottom: 99999px;
}

Solution 2 en utilisant le tableau 

Démo

.row {
    display: table;
}

[class*="col-"] {
    float: none;
    display: table-cell;
    vertical-align: top;
}

Solution 3 utilisant flex ajouté en août 2015. Les commentaires postés avant cela ne s'appliquent pas à cette solution.

Démo

.row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display:         flex;
  flex-wrap: wrap;
}
.row > [class*='col-'] {
  display: flex;
  flex-direction: column;
}
931
Popnoodles

Mise à jour 2018

Meilleure approche pour Bootstap 3.x - utilisation de CSS flexbox (et requiert un minimum de CSS) ..

.equal {
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
}

Exemple de flexbox Bootstrap de même hauteur

Pour appliquer uniquement la même boîte flexibles de hauteur à des points d'arrêt spécifiques (responsive), utilisez une requête multimédia. Par exemple, voici sm (768px) et plus:

@media (min-width: 768px) {
  .row.equal {
    display: flex;
    flex-wrap: wrap;
  }
}

Cette solution fonctionne également bien pour plusieurs lignes (encapsulation de colonne):
https://www.bootply.com/gCEXzPMehZ

Autres solutions de contournement

Ces options seront recommandées par d’autres, mais ne sont pas une bonne idée pour un design réactif. Celles-ci ne fonctionnent que pour les mises en page simples à une seule ligne sans habillage des colonnes.

1) Utilisation de énormes marges négatives et remplissage

2) Utilisation de display: table-cell (cette solution affecte également la grille sensible, de sorte qu'une requête @media ne peut être utilisée que pour appliquer un affichage table sur des écrans plus larges avant l'empilement vertical des colonnes)


Bootstrap 4

Flexbox est maintenant utilisé par défaut dans Bootstrap 4. Il n’est donc pas nécessaire que le CSS supplémentaire crée des colonnes de hauteur égale: http://www.codeply.com/go/IJYRI4LPwU

247
Zim

Pas de JavaScript nécessaire. Ajoutez simplement la classe .row-eq-height à votre .row existant comme ceci:

<div class="row row-eq-height">
  <div class="col-xs-12 col-sm-4 panel" style="background-color: red">
    some content
  </div>
  <div class="col-xs-6 col-sm-4 panel" style="background-color: yellow">
    kittenz
  <img src="http://placekitten.com/100/100">
  </div>
  <div class="col-xs-6 col-sm-4 panel" style="background-color: blue">
    some more content
  </div>
</div>

Conseil: si vous avez plus de 12 colonnes dans votre ligne, la grille d’amorçage ne pourra pas l’envelopper. Donc, ajoutez un nouveau div.row.row-eq-height chaque 12 colonnes.

Astuce: vous devrez peut-être ajouter 

<link rel="stylesheet" href="http://getbootstrap.com.vn/examples/equal-height-columns/equal-height-columns.css" />

à votre html

81
Kevin R.

Pour répondre à votre question, c’est tout ce dont vous avez besoin voir la démo complète avec les préfixes css :

/* Using col-xs media query breakpoint but you can change 481 to 768 to only apply to col-sm and above if you'd like*/

@media only screen and (min-width : 481px) {
    .flex-row {
        display: flex;
        flex-wrap: wrap;
    }
    .flex-row > [class*='col-'] {
        display: flex;
        flex-direction: column;
    }
    .flex-row.row:after, 
    .flex-row.row:before {
        display: flex;
    }
}

 Screenshot of Codepen

Pour ajouter la prise en charge du contenu des vignettes, flex dans les colonnes flex, comme dans la capture d'écran ci-dessus, ajoutez également ceci ... Notez que vous pouvez le faire également avec les panneaux: 

.flex-row .thumbnail,
.flex-row .caption {
    display: flex;
    flex: 1 0 auto;
    flex-direction: column;
}
.flex-text {
    flex-grow: 1;
}    
.flex-row img {
    width: 100%;
}

Bien que flexbox ne fonctionne pas dans IE9 et inférieur, vous pouvez utiliser la démo avec un repli en utilisant des balises conditionnelles avec quelque chose comme grilles javascript en tant que polyfill:

<!--[if lte IE 9]>

<![endif]-->

En ce qui concerne les deux autres exemples de la réponse acceptée ... La démonstration de table est une idée décente, mais sa mise en œuvre est incorrecte. L’application de cette CSS aux classes de colonnes bootstrap va sans aucun doute casser complètement le cadre de la grille. Vous devriez utiliser un sélecteur personnalisé pour un et deux. Les styles de tableau ne doivent pas être appliqués à [class*='col-'] ayant des largeurs définies. Cette méthode doit être utilisée UNIQUEMENT si vous voulez des colonnes de hauteur et de largeur égales égales. Il n'est pas destiné à d'autres mises en page et n'est PAS réactif. On peut toutefois le faire replier sur les écrans mobiles ...

<div class="table-row-equal">
<div class="thumbnail">
    Content...
</div>
<div class="thumbnail">
    Content...
</div>
</div>
@media only screen and (min-width : 480px){
    .table-row-equal {
        display: table;
        width: 100%;
        table-layout: fixed;
        border-spacing: 30px 0px;
        Word-wrap: break-Word;
    }
    .table-row-equal .thumbnail {
        float: none;
        display: table-cell;
        vertical-align: top;
        width: 1%;
    }
}

Enfin, la première démo de la réponse acceptée qui implémente une version du une vraie mise en page est un bon choix pour certaines situations, mais ne convient pas aux colonnes bootstrap. La raison en est que toutes les colonnes sont étendues à la hauteur du conteneur. Cela va donc également perturber la réactivité, car les colonnes ne sont pas étendues aux éléments voisins, mais à l'ensemble du conteneur. Cette méthode ne vous permettra pas non plus d’appliquer plus longtemps les marges du bas aux lignes et posera également d’autres problèmes, comme le défilement des balises d’ancrage.

Pour le code complet, voir le Codepen qui préfixe automatiquement le code de la flexbox.

55
Bryan Willis

Vous ne montrez qu'une seule ligne, votre cas d'utilisation peut donc être limité à cela. Juste au cas où vous auriez plusieurs lignes, ce plugin - github Javascript-grids - fonctionne parfaitement! Cela permet à chaque panneau de s’étendre jusqu’au plus grand, donnant ainsi à chaque rangée une hauteur potentiellement différente en fonction du plus grand C'est une solution jQuery vs css, mais je voulais la recommander comme une approche alternative.

41
globalSchmidt

Si vous voulez que cela fonctionne dans n’importe quel navigateur, utilisez javascript:

$( document ).ready(function() {
    var heights = $(".panel").map(function() {
        return $(this).height();
    }).get(),

    maxHeight = Math.max.apply(null, heights);

    $(".panel").height(maxHeight);
});
26
paulalexandru
.row-eq-height {
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display:         flex;
 }

De:

http://getbootstrap.com.vn/examples/equal-height-columns/equal-height-columns.css

8
eaglei22

solution jquery effrontée si quelqu'un est intéressé. Assurez-vous simplement que tous vos cols (el) ont un nom de classe commun ... fonctionne également si vous le liez à $ (window) .resize

function equal_cols(el)
{
    var h = 0;
    $(el).each(function(){
        $(this).css({'height':'auto'});
        if($(this).outerHeight() > h)
        {
            h = $(this).outerHeight();
        }
    });
    $(el).each(function(){
        $(this).css({'height':h});
    });
}

Utilisation

$(document).ready(function(){
   equal_cols('.selector');
});

Remarque: Ce message a été modifié conformément au commentaire de @Chris selon lequel le code n'a été défini qu'à la dernière hauteur la plus élevée dans la fonction $.each()

7
Marty

Vous pouvez également utiliser inline-flex, qui fonctionne assez bien et peut être un peu plus propre que de modifier chaque élément de ligne avec CSS.

Pour mon projet, je voulais que chaque ligne dont les éléments enfants avaient des bordures ait la même hauteur afin que les bordures paraissent en dents de scie. Pour cela, j'ai créé une classe CSS simple.

.row.borders{
    display: inline-flex;
    width: 100%;
}
7
Steffan Perry

Certaines des réponses précédentes expliquent comment donner aux divs la même hauteur, mais le problème est que, lorsque la largeur est trop étroite, les divs ne se superposent pas. Vous pouvez donc implémenter leurs réponses avec une partie supplémentaire. Pour chacun d'eux, vous pouvez utiliser le nom CSS indiqué ici en plus de la classe de ligne que vous utilisez. Le div devrait donc ressembler à ceci si vous voulez toujours que les div soient côte à côte:

<div class="row row-eq-height-xs">Your Content Here</div>

Pour tous les écrans:

.row-eq-height-xs {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;
    flex-direction: row;
}

Pour quand vous voulez utiliser sm:

.row-eq-height-sm {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;
    flex-direction: column;
}
@media (min-width:768px) {
    .row-eq-height-sm {
        flex-direction: row;
    }
}

Pour quand tu veux md:

.row-eq-height-md {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;
    flex-direction: column;
}
@media (min-width:992px) {
    .row-eq-height-md {
        flex-direction: row;
    }
}

Pour quand vous voulez utiliser lg:

.row-eq-height-lg {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display:         flex;
    flex-direction: column;
}
@media (min-width:1200px) {
    .row-eq-height-md {
        flex-direction: row;
    }
}

EDIT Basé sur un commentaire, il existe une solution plus simple, mais vous devez vous assurer de fournir des informations sur les colonnes à partir de la largeur souhaitée pour toutes les tailles jusqu'à xs (par exemple, <div class="col-md-3 col-sm-4 col-xs-12">:

.row-eq-height {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}
7
Zachary Weixelbaum

J'ai essayé beaucoup de suggestions faites dans ce fil et sur d'autres pages mais aucune solution n'a fonctionné à 100% dans tous les navigateurs.

J'ai donc expérimenté pas mal de temps et j'ai trouvé ceci .Une solution complète pour les colonnes Bootstrap Equal Height à l'aide de flexbox avec une seule classe. _ {Ceci fonctionne dans tous les principaux navigateurs IE10 +.

CSS:

.row.equal-cols {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.row.equal-cols:before,
.row.equal-cols:after {
  display: block;
}

.row.equal-cols > [class*='col-'] {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
}

.row.equal-cols > [class*='col-'] > * {
  -webkit-flex: 1 1 auto;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto; 
}

HTML:

<div class="container">
  <div class="row equal-cols">
    <div class="col-sm-4">
      <div class="content"></div>
    </div>
    <div class="col-sm-4">
      <div class="content"></div>
    </div>
    <div class="col-sm-4">
      <div class="content"></div>
    </div>
  </div>
</div>

Pour prendre en charge davantage de versions de IE, vous pouvez, par exemple, utiliser https://github.com/liabru/jquery-match-height et cibler toutes les colonnes enfants de .equal-cols. Comme ça:

// Create a check for IE9 (or any other specific browser).
if(IE9) {
  $(".row.equal-cols > [class*='col-']").matchHeight();
}

Sans ce remplissage multiple, les colonnes se comporteront comme les colonnes Bootstrap habituelles, ce qui constitue un très bon repli.

6
Adam Lindqvist

Je sais que je suis très en retard, mais vous pouvez maintenant utiliser l'attribut "min-height" pour atteindre votre objectif.

5
Faiz

Je suis surpris de ne pas pouvoir trouver une solution valable ici fin 2018. Je suis allé de l'avant et j'ai trouvé une solution Bootstrap 3 moi-même en utilisant flexbox. 

Exemple propre et simple:

 Example of matched column widths in Bootstrap 3

HTML

<div class="row row-equal">
    <div class="col-lg-4 col-md-4 col-sm-4 col-xs-12 col-equal">
        <p>Text</p>
    </div>
    <div class="col-lg-4 col-md-4 col-sm-4 col-xs-12 col-equal">
        <img src="//placehold.it/200x200">
    </div>
    <div class="col-lg-4 col-md-4 col-sm-4 col-xs-12 col-equal">
        <p>Text</p>
    </div>  
</div>

CSS

img {
  width: 100%;
}
p {
  padding: 2em;
}
@media (min-width: 768px) {
  .row-equal {
    display: flex;
    flex-wrap: wrap;
  }
  .col-equal {
    margin: auto;
  }
}

Voir la démo de travail: http://jsfiddle.net/5kmtfrny/

4
BuffMcBigHuge

Il y a un problème avec l'utilisation de la solution 1 lorsque vous l'appliquez uniquement sur des colonnes en lignes. Voudrais améliorer Solution 1.

 [class^="col-"]:not([class*="-12"]){
      margin-bottom: -99999px;
      padding-bottom: 99999px;
  }

(Désolé, je ne peux pas commenter la réponse de Popnoodles. Je n'ai pas assez de réputation)

voici ma solution (CSS compilé):

.row.row-xs-eq {
  display: table;
  table-layout: fixed;
  margin: 0;
}

.row.row-xs-eq::before {
  content: none;
}

.row.row-xs-eq::after {
  content: none;
}

.row.row-xs-eq > [class^='col-'] {
  display: table-cell;
  float: none;
  padding: 0;
}

@media (min-width: 768px) {
  .row.row-sm-eq {
    display: table;
    table-layout: fixed;
    margin: 0;
  }

  .row.row-sm-eq::before {
    content: none;
  }

  .row.row-sm-eq::after {
    content: none;
  }

  .row.row-sm-eq > [class^='col-'] {
    display: table-cell;
    float: none;
    padding: 0;
  }
}

@media (min-width: 992px) {
  .row.row-md-eq {
    display: table;
    table-layout: fixed;
    margin: 0;
  }

  .row.row-md-eq::before {
    content: none;
  }

  .row.row-md-eq::after {
    content: none;
  }

  .row.row-md-eq > [class^='col-'] {
    display: table-cell;
    float: none;
    padding: 0;
  }
}

@media (min-width: 1200px) {
  .row.row-lg-eq {
    display: table;
    table-layout: fixed;
    margin: 0;
  }

  .row.row-lg-eq::before {
    content: none;
  }

  .row.row-lg-eq::after {
    content: none;
  }

  .row.row-lg-eq > [class^='col-'] {
    display: table-cell;
    float: none;
    padding: 0;
  }
}

Donc, votre code ressemblerait à ceci:

<div class="row row-sm-eq">
  <!-- your old cols definition here -->
</div>

En gros, c'est le même système que vous utilisez avec les classes .col-* avec cette différence. Vous devez appliquer les classes .row-* à la ligne elle-même.

Avec .row-sm-eq, les colonnes seront empilées sur les écrans XS. Si vous n'avez pas besoin qu'ils soient empilés sur des écrans, vous pouvez utiliser .row-xs-eq.

La version SASS que nous utilisons réellement:

.row {
  @mixin row-eq-height {
    display: table;
    table-layout: fixed;
    margin: 0;

    &::before {
      content: none;
    }

    &::after {
      content: none;
    }

    > [class^='col-'] {
      display: table-cell;
      float: none;
      padding: 0;
    }
  }

  &.row-xs-eq {
    @include row-eq-height;
  }

  @media (min-width: $screen-sm-min) {
    &.row-sm-eq {
      @include row-eq-height;
    }
  }

  @media (min-width: $screen-md-min) {
    &.row-md-eq {
      @include row-eq-height;
    }
  }

  @media (min-width: $screen-lg-min) {
    &.row-lg-eq {
      @include row-eq-height;
    }
  }
}

Démo en direct


Remarque: mélanger .col-xs-12 et .col-xs-6 dans une seule ligne ne fonctionnerait pas correctement.

3
Alexander S.

Pour ceux qui recherchent une solution simple et rapide - si vous avez un ensemble relativement cohérent de contenu de bloc, définir une hauteur minimale sur la div plus grande que le plus gros bloc peut être plus facile à mettre en œuvre.

.align-box {
    min-height: 400px;
}
2
Neal

Voici ma méthode, j'ai utilisé flex avec quelques changements dans la requête des médias.

  @media (min-width: 0px) and (max-width: 767px) {
  .fsi-row-xs-level {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .fsi-row-sm-level {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .fsi-row-md-level {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}
@media (min-width: 1200px) {
  .fsi-row-lg-level {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}

puis ajouté les classes au parent qui étaient nécessaires.

<div class="row fsi-row-lg-level fsi-row-md-level">
<div class="col-sm-4">column 1</div>
<div class="col-sm-4">column 2</div>
<div class="col-sm-4">column 3</div>
</div>

J'utilise des points d'arrêt réactifs parce que le flux entrave généralement le caractère réactif standard du bootstrap.

2
Ajay Sathish

Si vous utilisez bootstrap 4 et recherchez des colonnes de hauteur égale, utilisez simplement row-eq-height pour parent div

  <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta.2/css/bootstrap.min.css" rel="stylesheet"/>
    <div class="row row-eq-height">
            <div class="col-xs-4" style="border: 1px solid grey;">.row.row-eq-height &gt; .col-xs-4</div>
            <div class="col-xs-4" style="border: 1px solid grey;">.row.row-eq-height &gt; .col-xs-4<br>this is<br>a much<br>taller<br>column<br>than the others</div>
            <div class="col-xs-4" style="border: 1px solid grey;">.row.row-eq-height &gt; .col-xs-4</div>
          </div>

Réf: http://getbootstrap.com.vn/examples/equal-height-columns/

2
Znaneswar

J'ai cherché une solution au même problème et en ai trouvé une qui fonctionnait! - Avec presque pas de code supplémentaire ..

voir https://medium.com/wdstack/bootstrap-equal-height-columns-d07bc934eb27 pour une bonne déco, et avec le resposne souhaité en bas, avec un lien.

https://www.codeply.com/go/EskIjvun4B

c’était la bonne façon de réagir pour moi…. une citation: ... 3 - Utilisez la boîte souple (le meilleur!)

À partir de 2017, le moyen le plus simple (et le plus simple) de créer des colonnes de hauteur égale dans un design réactif consiste à utiliser CSS3 flexbox. 

.row.display-flex {
  display: flex;
  flex-wrap: wrap;
}
.row.display-flex > [class*='col-'] {
  display: flex;
  flex-direction: column;
}

et simplement utiliser:

div class="container">
   <div class="row display-flex .... etc..
2
kfn

.row.container-height {
	overflow: hidden; 
}

.row.container-height > [class*="col-"]{
    margin-bottom: -99999px;
    padding-bottom: 99999px;
}

où .container-height est la classe de style à ajouter à un élément de style .row auquel tous ses enfants .col * ont la même hauteur.

L'application de ces styles uniquement à un .row spécifique (avec .container-height, comme dans l'exemple) évite également d'appliquer le débordement de marge et de remplissage à tous les fichiers .col *.

2
DarkScrolls

Meilleur là-bas: 

Github reflex - Docs

Fonctionne avec bootstrap

Mettre à jour:

  1. Inclure le CSS
  2. Mettez à jour votre code:

/*!
 *
 * Reflex v1.0
 *
 * Reflex is a flexbox grid which provides a way to take advantage of emerging
 * flexbox support while providing a fall back to inline-block on older browsers
 *
 * Built by Lee Jordan G.C.S.E.
 * email: [email protected]
 * github: https://github.com/leejordan
 *
 * Structure and calculations are inspired by Twitter bootstrap
 *
 */
.reflex-order-12 {
  -webkit-order: 12;
  -ms-flex-order: 12;
  order: 12;
}
.reflex-order-11 {
  -webkit-order: 11;
  -ms-flex-order: 11;
  order: 11;
}
.reflex-order-10 {
  -webkit-order: 10;
  -ms-flex-order: 10;
  order: 10;
}
.reflex-order-9 {
  -webkit-order: 9;
  -ms-flex-order: 9;
  order: 9;
}
.reflex-order-8 {
  -webkit-order: 8;
  -ms-flex-order: 8;
  order: 8;
}
.reflex-order-7 {
  -webkit-order: 7;
  -ms-flex-order: 7;
  order: 7;
}
.reflex-order-6 {
  -webkit-order: 6;
  -ms-flex-order: 6;
  order: 6;
}
.reflex-order-5 {
  -webkit-order: 5;
  -ms-flex-order: 5;
  order: 5;
}
.reflex-order-4 {
  -webkit-order: 4;
  -ms-flex-order: 4;
  order: 4;
}
.reflex-order-3 {
  -webkit-order: 3;
  -ms-flex-order: 3;
  order: 3;
}
.reflex-order-2 {
  -webkit-order: 2;
  -ms-flex-order: 2;
  order: 2;
}
.reflex-order-1 {
  -webkit-order: 1;
  -ms-flex-order: 1;
  order: 1;
}
.reflex-order-0 {
  -webkit-order: 0;
  -ms-flex-order: 0;
  order: 0;
}
.reflex-container {
  display: inline-block;
  display: -webkit-flex;
  display: flex;
  zoom: 1;
  *display: inline;
  margin: 0;
  padding: 0;
  position: relative;
  width: 100%;
  letter-spacing: -0.31em;
  *letter-spacing: normal;
  Word-spacing: -0.43em;
  list-style-type: none;
}
.reflex-container *,
.reflex-container:before,
.reflex-container:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 100%;
  letter-spacing: normal;
  Word-spacing: normal;
  white-space: normal;
}
.reflex-container *:before,
.reflex-container *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
[class*="reflex-col-"] {
  width: 100%;
  vertical-align: top;
  position: relative;
  display: inline-block;
  display: -webkit-flex;
  display: flex;
  zoom: 1;
  *display: inline;
  text-align: left;
  text-align: start;
}
.reflex-item {
  display: block;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
}
_:-ms-fullscreen,
:root .reflex-item {
  width: 100%;
}
.reflex-col-12 {
  width: 100%;
  *width: 99.9%;
}
.reflex-col-11 {
  width: 91.66666666666666%;
  *width: 91.56666666666666%;
}
.reflex-col-10 {
  width: 83.33333333333334%;
  *width: 83.23333333333335%;
}
.reflex-col-9 {
  width: 75%;
  *width: 74.9%;
}
.reflex-col-8 {
  width: 66.66666666666666%;
  *width: 66.56666666666666%;
}
.reflex-col-7 {
  width: 58.333333333333336%;
  *width: 58.233333333333334%;
}
.reflex-col-6 {
  width: 50%;
  *width: 49.9%;
}
.reflex-col-5 {
  width: 41.66666666666667%;
  *width: 41.56666666666667%;
}
.reflex-col-4 {
  width: 33.33333333333333%;
  *width: 33.23333333333333%;
}
.reflex-col-3 {
  width: 25%;
  *width: 24.9%;
}
.reflex-col-2 {
  width: 16.666666666666664%;
  *width: 16.566666666666663%;
}
.reflex-col-1 {
  width: 8.333333333333332%;
  *width: 8.233333333333333%;
}
@media (min-width: 480px) {
  .reflex-col-xs-12 {
    width: 100%;
    *width: 99.9%;
  }
  .reflex-col-xs-11 {
    width: 91.66666666666666%;
    *width: 91.56666666666666%;
  }
  .reflex-col-xs-10 {
    width: 83.33333333333334%;
    *width: 83.23333333333335%;
  }
  .reflex-col-xs-9 {
    width: 75%;
    *width: 74.9%;
  }
  .reflex-col-xs-8 {
    width: 66.66666666666666%;
    *width: 66.56666666666666%;
  }
  .reflex-col-xs-7 {
    width: 58.333333333333336%;
    *width: 58.233333333333334%;
  }
  .reflex-col-xs-6 {
    width: 50%;
    *width: 49.9%;
  }
  .reflex-col-xs-5 {
    width: 41.66666666666667%;
    *width: 41.56666666666667%;
  }
  .reflex-col-xs-4 {
    width: 33.33333333333333%;
    *width: 33.23333333333333%;
  }
  .reflex-col-xs-3 {
    width: 25%;
    *width: 24.9%;
  }
  .reflex-col-xs-2 {
    width: 16.666666666666664%;
    *width: 16.566666666666663%;
  }
  .reflex-col-xs-1 {
    width: 8.333333333333332%;
    *width: 8.233333333333333%;
  }
}
@media (min-width: 768px) {
  .reflex-col-sm-12 {
    width: 100%;
    *width: 99.9%;
  }
  .reflex-col-sm-11 {
    width: 91.66666666666666%;
    *width: 91.56666666666666%;
  }
  .reflex-col-sm-10 {
    width: 83.33333333333334%;
    *width: 83.23333333333335%;
  }
  .reflex-col-sm-9 {
    width: 75%;
    *width: 74.9%;
  }
  .reflex-col-sm-8 {
    width: 66.66666666666666%;
    *width: 66.56666666666666%;
  }
  .reflex-col-sm-7 {
    width: 58.333333333333336%;
    *width: 58.233333333333334%;
  }
  .reflex-col-sm-6 {
    width: 50%;
    *width: 49.9%;
  }
  .reflex-col-sm-5 {
    width: 41.66666666666667%;
    *width: 41.56666666666667%;
  }
  .reflex-col-sm-4 {
    width: 33.33333333333333%;
    *width: 33.23333333333333%;
  }
  .reflex-col-sm-3 {
    width: 25%;
    *width: 24.9%;
  }
  .reflex-col-sm-2 {
    width: 16.666666666666664%;
    *width: 16.566666666666663%;
  }
  .reflex-col-sm-1 {
    width: 8.333333333333332%;
    *width: 8.233333333333333%;
  }
}
@media (min-width: 992px) {
  .reflex-col-md-12 {
    width: 100%;
    *width: 99.9%;
  }
  .reflex-col-md-11 {
    width: 91.66666666666666%;
    *width: 91.56666666666666%;
  }
  .reflex-col-md-10 {
    width: 83.33333333333334%;
    *width: 83.23333333333335%;
  }
  .reflex-col-md-9 {
    width: 75%;
    *width: 74.9%;
  }
  .reflex-col-md-8 {
    width: 66.66666666666666%;
    *width: 66.56666666666666%;
  }
  .reflex-col-md-7 {
    width: 58.333333333333336%;
    *width: 58.233333333333334%;
  }
  .reflex-col-md-6 {
    width: 50%;
    *width: 49.9%;
  }
  .reflex-col-md-5 {
    width: 41.66666666666667%;
    *width: 41.56666666666667%;
  }
  .reflex-col-md-4 {
    width: 33.33333333333333%;
    *width: 33.23333333333333%;
  }
  .reflex-col-md-3 {
    width: 25%;
    *width: 24.9%;
  }
  .reflex-col-md-2 {
    width: 16.666666666666664%;
    *width: 16.566666666666663%;
  }
  .reflex-col-md-1 {
    width: 8.333333333333332%;
    *width: 8.233333333333333%;
  }
}
@media (min-width: 1200px) {
  .reflex-col-lg-12 {
    width: 100%;
    *width: 99.9%;
  }
  .reflex-col-lg-11 {
    width: 91.66666666666666%;
    *width: 91.56666666666666%;
  }
  .reflex-col-lg-10 {
    width: 83.33333333333334%;
    *width: 83.23333333333335%;
  }
  .reflex-col-lg-9 {
    width: 75%;
    *width: 74.9%;
  }
  .reflex-col-lg-8 {
    width: 66.66666666666666%;
    *width: 66.56666666666666%;
  }
  .reflex-col-lg-7 {
    width: 58.333333333333336%;
    *width: 58.233333333333334%;
  }
  .reflex-col-lg-6 {
    width: 50%;
    *width: 49.9%;
  }
  .reflex-col-lg-5 {
    width: 41.66666666666667%;
    *width: 41.56666666666667%;
  }
  .reflex-col-lg-4 {
    width: 33.33333333333333%;
    *width: 33.23333333333333%;
  }
  .reflex-col-lg-3 {
    width: 25%;
    *width: 24.9%;
  }
  .reflex-col-lg-2 {
    width: 16.666666666666664%;
    *width: 16.566666666666663%;
  }
  .reflex-col-lg-1 {
    width: 8.333333333333332%;
    *width: 8.233333333333333%;
  }
}
.reflex-wrap {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.reflex-wrap-reverse {
  -webkit-flex-wrap: wrap-reverse;
  flex-wrap: wrap-reverse;
}
.reflex-direction-row-reverse {
  -webkit-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.reflex-direction-column {
  -webkit-flex-direction: column;
  flex-direction: column;
}
.reflex-direction-column-reverse {
  -webkit-flex-direction: column-reverse;
  flex-direction: column-reverse;
}
.reflex-align-start {
  -webkit-align-items: flex-start;
  align-items: flex-start;
}
.reflex-align-end {
  -webkit-align-items: flex-end;
  align-items: flex-end;
}
.reflex-align-end [class*="reflex-col-"] {
  vertical-align: bottom;
}
.reflex-align-center {
  -webkit-align-items: center;
  align-items: center;
}
.reflex-align-center [class*="reflex-col-"] {
  vertical-align: middle;
}
.reflex-align-baseline {
  -webkit-align-items: baseline;
  align-items: baseline;
}
.reflex-align-baseline [class*="reflex-col-"] {
  vertical-align: baseline;
}
.reflex-align-content-start {
  -webkit-align-content: flex-start;
  align-content: flex-start;
}
.reflex-align-content-end {
  -webkit-align-content: flex-end;
  align-content: flex-end;
}
.reflex-align-content-end [class*="reflex-col-"] {
  vertical-align: bottom;
}
.reflex-align-content-center {
  -webkit-align-content: center;
  align-content: center;
}
.reflex-align-content-space-between {
  -webkit-align-content: space-between;
  align-content: space-between;
}
.reflex-align-content-space-around {
  -webkit-align-content: space-around;
  align-content: space-around;
}
.reflex-align-self-stretch {
  -webkit-align-self: stretch;
  align-self: stretch;
}
.reflex-align-self-start {
  -webkit-align-self: flex-start;
  align-self: flex-start;
}
.reflex-align-self-end {
  -webkit-align-self: flex-end;
  align-self: flex-end;
  vertical-align: bottom;
}
.reflex-align-self-center {
  -webkit-align-self: center;
  align-self: center;
  vertical-align: middle;
}
.reflex-align-self-baseline {
  -webkit-align-self: baseline;
  align-self: baseline;
  vertical-align: baseline;
}
.reflex-justify-start {
  text-align: left;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}
.reflex-justify-end {
  text-align: right;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}
.reflex-justify-center {
  text-align: center;
  -webkit-justify-content: center;
  justify-content: center;
}
.reflex-justify-space-between {
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.reflex-justify-space-around {
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
  -webkit-justify-content: space-around;
  justify-content: space-around;
}
.reflex-item-margin-sm {
  margin: 0 0.25em 0.5em;
}
.reflex-item-margin-md {
  margin: 0 0.5em 1em;
}
.reflex-item-margin-lg {
  margin: 0 1em 2em;
}
.reflex-item-content-margin-sm * {
  margin-right: 0.25em;
  margin-left: 0.25em;
}
.reflex-item-content-margin-md * {
  margin-right: 0.5em;
  margin-left: 0.25em;
}
.reflex-item-content-margin-lg * {
  margin-right: 1em;
  margin-left: 1em;
}
.reflex-img {
  display: inline-block;
  display: -webkit-flex;
  display: flex;
  zoom: 1;
  *display: inline;
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  margin-left: 0;
  margin-right: 0;
  max-width: 100%;
  width: 100%;
  height: auto;
}
.reflex-item-footer {
  margin-top: auto;
  margin-left: 0;
  margin-right: 0;
}
<link href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"/>
<link href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"/>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="reflex-container reflex-wrap">
  <div class="reflex-col-xs-12 reflex-col-sm-4 panel" style="background-color: red">
  some content
  </div>
  <div class="reflex-col-xs-6 reflex-col-sm-4 panel" style="background-color: yellow">
  kittenz
  <img src="http://upload.wikimedia.org/wikipedia/en/1/13/Matrona.jpg">
  </div>
  <div class="reflex-col-xs-6 reflex-col-sm-4 panel" style="background-color: blue">
  some more content
  </div>
</div>

2
öbl

J'utilise cette solution super facile avec clearfix, qui n'a pas d'effets secondaires. 

Voici un exemple sur AngularJS:

<div ng-repeat-start="item in list">
    <div class="col-lg-4 col-md-6 col-sm-12 col-xs-12"></div>
</div>
<div ng-repeat-end>
    <div ng-if="$index % 3 == 2" class="clearfix visible-lg"></div>
    <div ng-if="$index % 2 == 1" class="clearfix visible-md"></div>
</div>

Et encore un exemple sur PHP:

<?php foreach ($list as $i => $item): ?>
    <div class="col-lg-4 col-md-6 col-sm-12 col-xs-12"></div>
    <div class="clearfix visible-md"></div>
    <?php if ($i % 2 === 1): ?>
        <div class="clearfix visible-lg"></div>
    <?php endif; ?>
<?php endforeach; ?>
1
Oleg

Si cela vous semble judicieux, vous pouvez simplement ajouter un div vide à 12 colonnes après chaque pause, qui agit comme un diviseur qui épouse le bas de la cellule la plus haute de votre ligne.

<div class="row">
   <div class="col-xs-6">Some content</div>
   <div class="col-xs-6">
      Lots of content! Lots of content! Lots of content! Lots of content! Lots of content! 
   </div>
   <div id="spacer-div" class="col-xs-12"></div>
   <div class="col-xs-6">More content...</div>
</div><!--this You forgot to close -->

J'espère que cela t'aides!

1
Chris Staikos
@media (min-width: @screen-sm-min) {
    div.equal-height-sm {
        display: table;


        > div[class^='col-'] {
            display: table-cell;
            float: none;
            vertical-align: top;
        }
    }
}

<div class="equal-height-sm">
    <div class="col-xs-12 col-sm-7">Test<br/>Test<br/>Test</div>
    <div class="col-xs-12 col-sm-5">Test</div>
</div>

Exemple:

https://jsfiddle.net/b9chris/njcnex83/embedded/result/

Adapté de plusieurs réponses ici. Les réponses basées sur les boîtes flexibles sont la bonne solution une fois que IE8 et 9 sont morts et une fois Android 2.x est mort, mais ce n'est pas le cas en 2015 et ne le sera probablement pas en 2016. IE8 et 9 constituent toujours une solution 4- 6% d'utilisation en fonction de votre mesure, et pour de nombreux utilisateurs en entreprise, c'est bien pire. http://caniuse.com/#feat=flexbox

L'astuce display: table, display: table-cell est plus compatible avec les versions antérieures. Le seul problème grave en matière de compatibilité est un problème Safari qui force box-sizing: border-box, déjà appliqué à vos balises Bootstrap. http://caniuse.com/#feat=css-table

Vous pouvez évidemment ajouter plus de classes qui font des choses similaires, comme .equal-height-md. J'ai lié ces éléments aux divs pour le petit avantage en termes de performances de mon utilisation limitée, mais vous pouvez supprimer le tag pour le rendre plus généralisé, comme le reste de Bootstrap.

Notez que le jsfiddle utilise ici CSS, et donc, les choses que Less fournirait autrement sont codées en dur dans l'exemple lié. Par exemple, @ screen-sm-min a été remplacé par ce que Less insérerait - 768px.

1
Chris Moschini

Donc, oui, Bootstrap 4 fait que tous les colonnes d’une ligne soient de la même hauteur. Toutefois, si vous créez une bordure autour du contenu de la ligne, vous constaterez peut-être que les colonnes ne sont pas de la même hauteur!

Lorsque j'ai appliqué height: 100% à l'élément à l'intérieur du col, j'ai constaté que j'avais perdu ma marge.

Ma solution consiste à utiliser un remplissage sur la div du col (au lieu d'une marge sur l'élément interne). Ainsi:

<div class="container">
    <div class="row">
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
        <div class="col-lg-4 col-md-6 col-12 py-4">
            <div class="h-100 border round">
                        ...
            </div>
        </div>
    </div>
</div>

L'exemple de code ci-dessus utilise Bootstrap 4.1 pour créer un ensemble de neuf zones avec une bordure.

0
Dagmar

Je pensais simplement ajouter que la réponse donnée par Dr.Flink peut également être appliquée à un bloc Bootstrap 3 form-horizontal - ce qui peut s'avérer très pratique si vous souhaitez utiliser des couleurs d'arrière-plan pour chaque cellule. Pour que cela fonctionne avec les formulaires bootstrap, vous devez envelopper le contenu du formulaire, qui sert simplement à répliquer une structure de type tableau.

L'exemple ci-dessous fournit également le CSS qui illustre une requête de média supplémentaire permettant à Bootstrap 3 de simplement prendre le contrôle et de faire son travail normal sur le ou les écrans plus petits. Cela fonctionne aussi dans IE8 +.

Exemple:

<form class="form-horizontal" role="form">

  <div class="form-wrapper">
    <div class="form-group">
      <label class="col-xs-12 col-sm-2 control-label">My Label</label>
      <div class="col-xs-12 col-sm-10">
        Some content
      </div>
    </div>
  </div>

</form>
.form-wrapper {
  display: table;
}

.form-wrapper .form-group {
  display: table-row;
}

.form-wrapper .form-group .control-label {
  display: table-cell;
  float: none;
}

.form-wrapper .form-group label + div {
  display: table-cell;
  float: none;
}

@media (max-width: 768px) {
  .form-wrapper {
    display: inherit;
  }
  .form-wrapper .form-group {
    display: block;
  }
  .form-wrapper .form-group .control-label {
    display: inherit;
  }
  .form-wrapper .form-group label + div {
    display: inherit;
  }
}
0
JoeTidee

Vous pouvez envelopper les colonnes dans une div

<div class="row">
<div class="col-md-12>
  <div class="col-xs-12 col-sm-4 panel" style="background-color: red">
  some content
  </div>
  <div class="col-xs-6 col-sm-4 panel" style="background-color: yellow">
  kittenz
  <img src="http://placekitten.com/100/100">
  </div>
  <div class="col-xs-6 col-sm-4 panel" style="background-color: blue">
  some more content
  </div>
</div>
</div>
0
Tom Kur

HTML

<div class="container-fluid">
<div class="row-fluid">
<div class="span4 option2">
<p>left column </p>
<p>The first column has to be the longest The first column has to be the longes</p>
</div>

<div class="span4 option2">
<p>middle column</p>
</div>

<div class="span4 option2">
<p>right column </p>
<p>right column </p>
<p>right column </p>
<p>right column </p>
<p>right column </p>
</div>
</div>
</div>

CSS

.option2 { background: red; border: black 1px solid; color: white; }

JS

$('.option2').css({
    'height': $('.option2').height()
});
0
Pacific P. Regmi

Essayez ceci à travers flex-box

.container {
	display: flex;
	padding-bottom: 50px;
}
.col {
	background: blue;
	padding: 30px;
}

.col.center {
	background: red;
	height: 100px;
	margin-bottom: -50px;
}
<div class="container">
  <div class="col">Left</div>
  <div class="col center">Center</div>
  <div class="col">Right</div>
</div>

Live JSFiddle - https://jsfiddle.net/grinmax_/spsn4fnq/

0
grinmax

03/19/2019

** Solution Bootstrap 4 à hauteur égale **

Bootstrap Utilities/flex à hauteur égale

Exemple vivant à Codepen

Hauteur égale par la classe bootstrap avec div parent fixé height ou min-height

<div class="d-flex align-content-stretch flex-wrap" style="min-height: 200px">
    <div>Flex height test text for example , Flex height test text for example </div>
    <div>Flex item</div>
    <div>Flex item</div>
    <div>Flex item</div>
 </div>
.bd-highlight {
    background-color: rgba(86,61,124,.15);
    border: 1px solid rgba(86,61,124,.15);
}
.fixed-height-200 {
  min-height: 200px;
}
<link href="https://cdnjs.cloudflare.com/ajax/libs/Twitter-bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<br><br><br>
<div class="d-flex align-content-stretch flex-wrap fixed-height-200">
    <div class="p-2 bd-highlight">Flex item <br> 1111111111</div>
    <div class="p-2 bd-highlight bg-danger">Flex item</div>
    <div class="p-2 bd-highlight">Flex item</div>
    <div class="p-2 bd-highlight bg-info">Flex item</div>
    <div class="p-2 bd-highlight">Flex item</div>
    <div class="p-2 bd-highlight">Flex item</div>
    <div class="p-2 bd-highlight bg-light">Flex item <br> 1111111111</div>
    <div class="p-2 bd-highlight">Flex item <br> 1111111111</div>
    <div class="p-2 bd-highlight">Flex item <br> 1111111111</div>
    <div class="p-2 bd-highlight">Flex item</div>
    <div class="p-2 bd-highlight bg-primary">Flex item</div>
    <div class="p-2 bd-highlight">Flex item</div>
    <div class="p-2 bd-highlight">Flex item</div>
    <div class="p-2 bd-highlight">Flex item</div>
    <div class="p-2 bd-highlight">Flex item</div>
</div>
0
MD Ashik