web-dev-qa-db-fra.com

Puis-je commencer une nouvelle ligne de cellules de table CSS sans un élément wrapper de ligne?

Étant donné le balisage comme ceci:

<div class="a">A</div>
<div class="b">B</div>
<div class="a">A</div>
<div class="b">B</div>
<div class="a">A</div>
<div class="b">B</div>

Est-il possible de styler ce document de la manière suivante:

|-------|---------|
|       |         |
|   A   |    B    |
|       |         |
|-------|---------|
|       |         |
|   A   |    B    |
|       |         |
|-------|---------|
|       |         |
|   A   |    B    |
|       |         |
|-------|---------|

(et si le contenu en A ou B est plus long, son voisin se développera pour correspondre à sa hauteur)…

sans aucun balisage supplémentaire?

Je comprends que donner .a et .b une valeur display de table-cell créerait simplement cette grande ligne.

Quelle est la solution?

21
Alan H.

Pas sans flexbox , qui n’a pas encore atterri dans plusieurs grands navigateurs, semble faire l’objet d’un consensus.

4
Alan H.

Non, je pense que ce n'est pas possible "sans aucune majoration supplémentaire". Il faut:

  • div wrapper avec display: table-row; contenant A et B "cellules"
  • JavaScript avec des auditeurs sur divs, qui déterminera max des hauteurs de A anb B dans chaque paire et le fixera à une valeur plus petite

Solution pour le second:

CSS:

.a, .b {
    padding: 0.5em;
    float: left;
}
.a:nth-child(n+1) {
    clear: both;
}

jQuery:

$(function() {
    var max_width_a = 0, max_width_b = 0;
    $("div.a").each(function() {
        var elem_a = $(this),
            elem_b = elem_a.next("div.b"),
            height_a = elem_a.height(),
            height_b = elem_b.height(),
            pair = [elem_a, elem_b];

        max_width_a = Math.max(max_width_a, elem_a.width());    
        max_width_b = Math.max(max_width_b, elem_b.width());  
        $(pair).height(Math.max(height_a, height_b));
    }).width(max_width_a);
    $("div.b").width(max_width_b);
});

J'ai mis à jour ton violon. Fonctionne sur le document prêt, vous devez le personnaliser si vous voulez déterminer les changements de hauteur dynamiques.

Faites-moi savoir si je dois expliquer comment cela fonctionne. Bien sûr, vous pouvez forcer la largeur de div.a et div.b en CSS et ne pas vérifier la largeur maximale avec jQuery (dans ce cas, vous ne devrez déterminer que la hauteur maximale de chaque paire).

3
Wirone

non, ce n'est pas possible sans donner à chaque ligne un wrapper.

voici une solution css pure avec un seul emballage contenant (par rangée)

.row { 
    background-color: #ccc;
    float: left;
    margin: 10px 0;
    padding: 1em;
    width: 50%;
    }
.a {
    float: left;
    width: 45%;
    }
.b {
    float: right;
    width: 45%;
    }

et le html

<div class="row">
    <div class="a">Mofo break yo neck, yaonna chung fizzle, bizzle dizzle dang dolor boom shackalack augue. Fizzle izzle away sit its fo riz</div>
    <div class="b">Lorizzle hizzle dolizzle sit amet, brizzle adipiscing elizzle. Nullam i saw beyonces tizzles and my pizzle went crizzle shizzlin dizzle, fo shizzle mah nizzle fo rizzle, mah home g-dizzle sizzle, suscipit quizzle, i saw beyonces tizzles and my pizzle went crizzle vizzle, arcu. Break yo neck, yall shiznit tortor. Sed eros. Ma nizzle izzle you son of a bizzle dapibizzle turpishizzle. Integizzle check out this velit sed fo.</div>
</div>
<div class="row">
    <div class="a">Sizzle ullamcorpizzle. Shut the shizzle up sagittizzle dizzle a shiznit. Vestibulizzle you son of a bizzle ipsizzle primis izzle faucibus orci pot et ultrices posuere Dope Fo shizzle; Crazy vestibulizzle. Fo shizzle my nizzle habitant morbi tristique senectus ma nizzle netizzle izzle tellivizzle famizzle turpis hizzle. Donizzle tempor hendrerit hizzle. Aliquizzle erat volutpat. </div>
    <div class="b">Vivamizzle sagittis.rttitizzle izzle, boom shackalack hizzle, orci. Integizzle hizzle funky fresh lectus. </div>
</div>
<div class="row">
    <div class="a">Donizzle tempor hendrerit hizzle. Aliquizzle erat volutpat. Things crunk fizzle, scelerisque bizzle, daahng dawg the bizzle, crackalackin shiznit, arcu. Daahng dawg elizzle. Crazy fermentizzle, est izzlot purizzle , bibendizzle sizzle amizzle, fo shizzle vehicula, fo shizzle my nizzle malesuada, shizznit. Aenizzle fizzle ipsizzle izzle est ullamcorpizzle tincidunt. Cool quizzle. Mauris ligula urna, tempizzle shut th</div>
    <div class="b">Mofo break yo neck, yall fo shizzle izzle leo bibendum crackalackin. Vivamizzle shit tortor vizzle away. Brizzle malesuada fo magna. Dang commodo, nisl nizzle go to hizzle egestizzle, magna dolor w</div>
</div>

si vous voulez que a et b aient des couleurs de fond différentes, vous devrez utiliser height: 100%

1
kristina childs

J'ai écrit un plugin jQuery qui accomplit cela. Il convertit une disposition float en une disposition display:table et gère les lignes pour vous. Les largeurs de cellules sont traitées automatiquement sans script (beaucoup plus rapide). C'est réactif aussi. Ça s'appelle WRECKER !! Hahahaha !.

svachon.com/blog/wrecker-responsive-equal-height-columns-and-rows/

1
Steven Vachon

je mets cela dans un commentaire, mais je devrais probablement en faire une réponse. voici comment faire la même chose (en utilisant des rangées) en forçant une hauteur de 100%

.row {
    background-color: #ccc;
    float: left;
    margin: 10px 0;
    padding: 1em;
    width: 50%;
}

#container_a {
    background-color: blue;
    float: left;
    position: relative;
    right: 50%;
    width: 100%;
}
#container_b {
    background-color: red;
    float: left;
    overflow: hidden;
    position: relative;
    right: 0;
    width: 100%;
}
#column_a {
    float: left;
    left: 50%;
    overflow: hidden;
    position: relative;
    width: 46%;
}
#column_b {
    float: left;
    left: 56%;
    overflow: hidden;
    position: relative;
    width: 46%;
}

et le html

<div class="row">
    <div id="container_b">
        <div id="container_a">
            <div id="column_a">Lorizzle hizzle dolizzle sit amet, brizzle adipiscing elizzle. Nullam i saw beyonces tizzles and my pizzle went crizzle shizzlin dizzle, fo shizzle mah nizzle fo rizzle, mah home g-dizzle sizzle, suscipit quizzle, i saw beyonces tizzles and my pizzle went crizzle vizzle, arcu. Break yo neck, yall shiznit tortor. Sed eros. Ma nizzle izzle you son of a bizzle dapibizzle turpishizzle. Integizzle check out this velit sed fo.</div>
            <div id="column_b">Vivamizzle sagittis.rttitizzle izzle, boom shackalack hizzle, orci. Integizzle hizzle funky fresh lectus. </div>
        </div>
    </div>
</div>
<div class="row">
    <div id="container_b">
        <div id="container_a">
            <div id="column_a">Lorizzle hizzle dolizzle sit amet, brizzle adipiscing elizzle. Nullam i saw beyonces tizzles and my pizzle went crizzle shizzlin dizzle, fo shizzle mah nizzle fo rizzle, mah home g-dizzle sizzle, suscipit quizzle, i saw beyonces tizzles and my pizzle went crizzle vizzle, arcu. Break yo neck, yall shiznit tortor. Sed eros. Ma nizzle izzle you son of a bizzle dapibizzle turpishizzle. Integizzle check out this velit sed fo.</div>
            <div id="column_b">Vivamizzle sagittis.rttitizzle izzle, boom shackalack hizzle, orci. Integizzle hizzle funky fresh lectus. </div>
        </div>
    </div>
</div>
<div class="row">
    <div id="container_b">
        <div id="container_a">
            <div id="column_a">Lorizzle hizzle dolizzle sit amet, brizzle adipiscing elizzle. Nullam i saw beyonces tizzles and my pizzle went crizzle shizzlin dizzle, fo shizzle mah nizzle fo rizzle, mah home g-dizzle sizzle, suscipit quizzle, i saw beyonces tizzles and my pizzle went crizzle vizzle, arcu. Break yo neck, yall shiznit tortor. Sed eros. Ma nizzle izzle you son of a bizzle dapibizzle turpishizzle. Integizzle check out this velit sed fo.</div>
            <div id="column_b">Vivamizzle sagittis.rttitizzle izzle, boom shackalack hizzle, orci. Integizzle hizzle funky fresh lectus. </div>
        </div>
    </div>
</div>
1
kristina childs

Vous POUVEZ faire cela sans flexbox, mais vous devrez utiliser nth-child (). Regardez cette réponse: https://stackoverflow.com/a/12589629/740836

1
Nick Budden

Je ne peux pas penser à un moyen sans un wrapper de ligne, mais si vous savez que la largeur exacte de la div externe ne changera jamais, il est possible d'y parvenir. Ma solution consiste à utiliser la taille de l’emballage pour adapter a et b sur la même ligne, puis les suivants a et b seront automatiquement déplacés de manière à ce qu’ils reviennent à la ligne suivante. Cependant, si la largeur de l'emballage diminue, a et b ne suivront pas la même ligne.

<div id="wrapper">
  <div class="a">A</div>
  <div class="b">B</div>
  <div class="a">A</div>
  <div class="b">B</div>
</div>

<style>
#wrapper { width: 500px;}
.a { background-color:green; float:left; width:50%;}
 .b {background-color:red;float:left;width:50%;}
</style>

http://jsfiddle.net/Lf0arzkn/1/

0
eternal

Oui, c'est possible avec display: contents si vous vous limitez à un enfant (comme un nœud de texte ou un élément, mais en réalité en termes de boîte CSS) dans la cellule juste avant (ou après si vous adaptez ma solution en conséquence) la rupture.

<style>
#d1::after {
    content: "";
    display: table-row;
}
</style>
<div style="display: table">
<div id="d1" style="display: contents">aaaaaaaaaa</div>
<div style="display: table-cell">bbbbbbbbb</div>
</div>
0
ByteEater