css - flexbox 布局 設定 margin的問題
PHP中文网
PHP中文网 2017-04-17 11:55:59
0
5
739

最近在練習flexbox 所以先不使用bootstrap
我想要我的布局如圖 每個1 2 3 4 5 之間可以自己設定margin

如圖:

我剛知道了,只要在flexbox中設置 justify-content:space-between; ,就可以把1row剩餘的width,平均分配成margin了,而設置了flex-flow:row wrap;的話,當子項目超過100%就會自動斷行,比如說現在有個container和box,大致會是這樣。

.container{
    display:flex;
    justify-content:space-between;
    flex-flow:row wrap;
}

.box{
   flex-basis:30%;
}

如圖:

DEMO: https://jsfiddle.net/jasonHsi...

後來為了調整,又找到了一個屬性 flex-grow:1; 可以讓row剩下的width,被每個flex子項目平均分配,就是把justify-content拿掉,加上flex-grow:1;

.container{
    display:flex;
    flex-flow:row wrap;
}

.box{
   flex-basis:30%;
    flex-grow:1;
}

如圖:


DEMO:
https://jsfiddle.net/jasonHsi...

雖然很不錯,但是離我一開始想要做的布局有些出入,請問要如何利用flexbox完成這樣的布局呢?

PHP中文网
PHP中文网

认证0级讲师

全部回覆(5)
黄舟
<p class="row">
  <p class="col">1</p>
  <p class="col">2</p>
  <p class="col">3</p>
  <p class="col">4</p>
  <p class="col">5</p>
</p>
.row{
  display: flex;
  flex-wrap: wrap;
  background: red;
}
.col{
  box-sizing: border-box; 
  width: 30.333333%;
  margin: 10px 1.5%;
  background:#eee;
  height: 120px;
}

效果:codepen

洪涛

說一個簡單實現,就是使用:after創建一個偽元素填充最後一個位置,來達到你要的效果。

另外,flex佈局不是萬能的,多重佈局之間融會貫通,才能發揮最大優勢

黄舟

一般使用flex 是為了自動計算剩餘空間, 依你說的這種情景,還是使用inline-block 或浮動 比較合適。

阿神

雷雷

巴扎黑

結尾放入幾個高度為0的空標籤,寬度和你row一樣寬的元素

<p class="row">
  <p class="col">1</p>
  <p class="col">2</p>
  <p class="col">3</p>
  <p class="col">4</p>
  <p class="col">5</p>
  <p class="fix"></p>
  <p class="fix"></p>
</p>
.row{
  display: flex;
  justify-content:space-between;
  flex-flow:row wrap;
  background: red;
}
.col{
  box-sizing: border-box; 
  width: 30.333333%;
  background:#eee;
  height: 120px;
  margin:10px 0;
}
.fix {
  width: 30.333333%;
  height:0;
  margin: 0;
}
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板