flexbox以前有接觸,寫項目時也用過,但也只是簡單的,對其也是似懂非懂,因此今天下定決心把這個再學一遍,由於似懂非懂就是不懂css
本文主要是的demo演示,想看flexbox語法 請移步flexbox語法html
本文主要分兩大部分:flexbox的Demo與常見的佈局佈局
如下demo的圖片與css代碼從左至右從上到下一一對應flex
htmlflexbox
<div class='box-1'> <span>一</span> </div>
cssspa
.box-1{ /* 一個元素 */ 左上角 display: flex; /* 右上角 */ justify-content: flex-end; /* 左下角 */ align-items: flex-end; /* 右下角 */ justify-content: flex-end; align-items: flex-end; }
html3d
<div class='box-1'> <span>一</span> </div>
csscode
.box-1{ /* 頂部水平居中 */ justify-content: center; /* 左垂直居中 */ align-items: center; /* 右垂直居中 */ justify-content: flex-end; align-items: center; /* 垂直和水平居中 */ justify-content: center; align-items: center; */ /* 底部水平居中 */ justify-content: center; align-items: flex-end; }
html htm
<div class='box-1'> <span>一</span> <span>二</span> </div>
cssblog
.box-1{ /* 二個元素 */ display: flex; /* 水平兩端對齊,項目之間的間隔都相等*/ justify-content: space-between; /* 左垂直兩端對齊,項目之間的間隔相等 flex-direction: column : 主軸爲垂直方向,起點在上沿。*/ flex-direction: column; justify-content: space-between; /* 垂直居中兩端對齊,項目之間的間隔相等 flex-direction: column : 主軸爲垂直方向,起點在上沿。align-items這時就表明水平方向*/ flex-direction: column; justify-content: space-between; align-items: center; /* 右垂直兩端對齊,項目之間的間隔相等 */ flex-direction: column; justify-content: space-between; align-items: flex-end; /* 水平居中兩端對齊,項目之間的間隔都相等 */ justify-content: space-between; align-items: center; /* 底部兩端對齊,項目之間的間隔都相等 */ justify-content: space-between; align-items: flex-end; } /* 兩元素左對角對齊 */ .box-1{ justify-content: space-between; } span:nth-child(2){ align-self: flex-end; }
html
<div class='box-1'> <span>一</span> <span>二</span> <span>三</span> <div>
css
.box-1{ /* 三元素左對角對齊 */ justify-content: space-between; /* 倒三角 */ justify-content: space-between; } /* 三元素左對角對齊 */ span:nth-child(2){ align-self: center; } span:nth-child(3){ align-self: flex-end; } /* 倒三角 */ span:nth-child(2){ align-self: flex-end; }
html
<div class='box-1'> <span>一</span> <span>二</span> <span>三</span> <span>四</span> <span>五</span> <span>六</span> <span>七</span> <span>八</span> <span>九</span> <span>十</span> <span>十一</span> <span>十二</span> <span>十三</span> </div>
css
.box-1{ /* 十三元素換行操做 */ display: flex; flex-wrap: wrap; justify-content: flex-end; align-content: space-between; }
html
<div class="box-2"> <div class="column"> <span>1</span> <span>2</span> </div> <div class="column"> <span>3</span> <span>4</span> </div> </div>
css
.box-2 { float: left; width: 400px; height: 400px; border: solid 1px black; display: flex; flex-wrap: wrap; align-content: space-between; } .column { flex-basis: 100%; display:flex; justify-content: space-between; } .column span{ display: inline-block; text-align: center; color: #fff; width: 80px; height: 80px; border-radius: 50%; background-color: #000; }
html
<div class="box-3"> <div class="row"> <span>1</span> <span>2</span> <span>3</span> </div> <div class="row"> <span>4</span> <span>5</span> <span>6</span> </div> <div class="row"> <span>7</span> <span>8</span> <span>9</span> </div> </div>
css
.box-3 { width: 180px; height: 190px; border: solid 1px black; display: flex; flex-wrap: wrap; align-items: center; } .row{ flex-basis: 100%; display: flex; justify-content: space-between; flex: 1; } .box-3 span { display: inline-block; text-align: center; color: #fff; width: 50px; height: 50px; border-radius: 50%; background-color: #000; }
html
<h1>網格佈局</h1> <div class="grid grid1"> <div class="grid-cell u-lof2" >1/2</div> <div class="grid-cell">auto</div> <div class="grid-cell u-lof3">1/3</div> <div class="grid-cell u-lof3">1/3</div> <div class="grid-cell">auto</div> <div class="grid-cell u-lof3">1/3</div> <div class="grid-cell u-lof4">1/4</div> <div class="grid-cell u-lof3">1/3</div> <div class="grid-cell">auto</div> </div>
css
.grid { display: flex; margin:30px auto; width: 100%; text-align: center; border-radius:6px; background-color: #eee; box-shadow: 0 2px 10px 0 #111 , insert 0 2px 0 0 #fff; } .grid .grid-cell{ margin: 10px; height: 30px; border-radius: 5px; background-color: #454545; line-height: 30px; text-align: center; color: #fff; } .grid1 { display: flex; flex-wrap: wrap; } .grid1 .grid-cell{ flex:1; } .grid1 .u-lof2 { flex:0 0 50%; } .grid1 .u-lof3{ flex: 0 0 33.333%; } .grid1 .u-lof4{ flex: 0 0 25% }
html
<h1>聖盃佈局</h1> <div class="grid holy-grid"> <div class="header">header</div> <div class="content"> <div class="nav">nav</div> <div class="main">main</div> <div class="ads">ads</div> </div> <div class="footer">footer</div> </div>
css
.holy-grid { display: flex; flex-direction: column; } .holy-grid .header, .holy-grid .footer{ flex:1; height: 40px; background-color: #676767; line-height: 40px; color: #fff; } .holy-grid .header { border-top-right-radius: 5px; border-top-left-radius: 5px; } .holy-grid .footer { border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; } .holy-grid .content{ display: flex; flex:1; min-height: 300px; line-height: 300px; } .holy-grid .nav, .holy-grid .ads{ flex: 0 0 70px; } .holy-grid .main{ flex:1; } .holy-grid .nav { order: 1; background-color: #a1a1a1; } .holy-grid .ads { background-color: #d3d3d3; }
html
<h1>懸掛式佈局</h1> <div class="Media"> <img src="./jr.png" alt="" class="Media-figure"> <div class="Media-body"> <p class="body-title">JR禁賽真正緣由曝光:他向助教身上撒了一碗湯</p> <div class="body-content"> 騰訊體育訊(文/Brian Windhorst和Dave McMenamin,ESPN撰稿人) 北京時間3月3日,據ESPN報道,騎士後衛JR-史密斯被球隊禁賽一場的緣由曝光,原來是由於他向助理教練達蒙-瓊斯身上撒了一碗湯。 </div> </div> </div>
css
.Media { display: flex; align-items: flex-start; } .Media-figure { margin-right: 1em; width: 200px; height: 100px; } .Media-body { border-radius: 5px; background-color: #eee; flex:1; height: 100px; } .Media-body .body-title{ font-weight: bold; margin:0; } .Media-body .body-content { margin:0; }
注意:設置align-items屬性時必須保證容器有高度
.item {flex: 1;} .item { flex-grow: 1; flex-shrink: 1; flex-basis: 0%; }
這二者是等價的,三者含義見flexbox語法
參考文獻: