如何使用flexbox模仿浮动?

时间:2020-07-14 11:34:25

标签: css flexbox css-float

我正在尝试像float一样使用flexbox。我希望一个孩子在右边形成一列,其余的孩子在左边形成另一列。我无法添加其他HTML,只能使用CSS。

我已经找到了解决方法,但是我只需要两列都在顶部对齐。我当前的代码的左列略低于右列。

https://jsfiddle.net/o2fbtuLc/

.parent {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}

.child {
  max-width: 48%;
}

.right {
  margin-left: auto;
}
<div class="parent">
  <div class="child right">Right</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
</div>

4 个答案:

答案 0 :(得分:0)

您可以使用order。另外,我删除了flex-direction: column,并为第二个元素之后的元素添加了max-width: 100%

.parent {
  display: flex;
  flex-wrap: wrap;
}

.child {
  width: 100%;
  max-width: 48%;
}

.child:nth-child(2) {
  order: 1;
}

.child:nth-child(3) {
  order: 3;
}

.child:nth-child(4) {
  order: 4;
}

.right {
  order: 2;
}

.child:nth-child(n + 3) {
  max-width: 100%;
}
<div class="parent">
  <div class="child right">Right</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
</div>

如果.right较高,我们可以考虑使用grid-area

.parent {
  display: grid;
  grid-template-areas:  "left1 right" 
                        "left2 right" 
                        "left3 right";
}

.child {
  width: 100%;
  background: blue;
  height: 30px;
}

.child:nth-child(2) {
  grid-area: left1;
}

.child:nth-child(3) {
  grid-area: left2;
}

.child:nth-child(4) {
  grid-area: left3;
}

.right {
  background: red;
  height: 80px;
  grid-area: right;
}
<div class="parent">
  <div class="child right">Right</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
</div>

答案 1 :(得分:0)

CSS-Grid可以做到:

.parent {
  display: grid;
  grid-template-columns: auto auto;
  grid-auto-flow: column;
}

.child {
  max-width: 48%;
  grid-column: 1;
  border: 1px solid green;
}

.right {
  grid-column: 2;
}
<div class="parent">
  <div class="child right">Right</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
  <div class="child right">Right</div>
</div>

答案 2 :(得分:0)

如果您想避免grid (可能涉及IE 11?),通过表格显示的旧方法也可以做到:

.parent {
  display: table;
  width: 100%;
  direction: rtl;/* alike a flow column reverse here */
  text-align: left;
  border: solid;
}

.child {
  direction: ltr;/* ! reset flow direction  ;)*/
  border: solid;
}

.right {/* i will also expand if first col is longer than myself  */
  display: table-cell;
  width: 50%;/* set column width here ! left over will be for the other one(s). */
}

/* margins ? */
.bis {border-spacing:2px;}
.bis .child {margin-right:2px;}
.bis .right + .child ~ .child {margin-top:2px;}
.bis .right{text-align:center;vertical-align:middle;
<div class="parent">
  <div class="child right">Right</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
  <div class="child">Left</div>
</div>
<hr>
<div class="parent bis">
  <div class="child right">possible gaps /  VH-align</div>
  <div class="child">Left</div>
  <div class="child">two<br>lines</div>
  <div class="child">Left</div>
</div>

答案 3 :(得分:0)

只需按预期使用flexbox!

.parent {
  display: flex;
  justify-content:space-between;
}
<div class="parent">
 <div>
  <div class="child">Left</div>
  <div class="child">Left</div>
  <div class="child">Left</div></div>
  <div class="child right">Right</div>
</div>