以前的隨筆從阮一峯老師那裏學到了flex的基本用法及做用,如今來把flex具體運用到實例中,看看flex的彈性佈局效果。css
1. flex設置元素垂直居中對齊html
在以前的一篇文章中記載過如何垂直居中對齊,方法有不少,可是在學習了flex佈局以後,垂直居中更加容易實現佈局
HTML代碼:學習
<div class="demo">
<div class="inner">
<p>這是一個測試這是一個測試這是一個測試這是一個測試這是一個測試</p>
</div>
</div>
CSS代碼:測試
.demo{ width: 500px; height: 300px; border: 1px solid purple; display: flex; /*設置爲flex佈局*/ justify-content: center; /*水平居中*/ align-items: center; /*垂直居中*/
} .inner{ width: 160px; height: 160px; font-size: 26px; border: 1px solid red;
}
效果如圖:flex
2. 用flex佈局製做導航欄spa
之前在寫導航欄的時候,老是用float或者display:inline-block實現,可是這兩種方法都會有各類問題,好比浮動會影響父元素以及兄弟元素的樣式,須要清除浮動3d
如今用flex會很方便,而且是彈性佈局code
HTML代碼:htm
<ul>
<li>音樂</li>
<li>影視</li>
<li>旅遊</li>
</ul>
CSS代碼:
ul{ display: flex;
} li{ flex: 1; text-align: center; line-height: 100px;
}
效果如圖所示:
咱們只要在HTML代碼裏面多加兩個li元素,導航便彈性變化
不須要改變css代碼,便可在導航欄中增長項目
3. 有時候須要作成左圖右文字的樣式,以下圖所示:
此時用flex會很方便
HTML代碼:
<div class="demo">
<div class="left"></div>
<div class="right">
<p>Iphone7 PLUS XXXXXXXXXX</p>
<span>總人數99</span>
<span>剩餘人數33</span>
<div class="btn">當即參與</div>
</div>
</div>
CSS代碼:
.demo{ display: flex; /*設置爲flex佈局*/ justify-content: space-around;
} .demo > div{ flex: none;
} .left{ width: 200px; height: 200px; background: #d4cdcd;
} .right{ width: 380px; height: 200px;
}
甚至有多列布局,
HTML代碼:
<div class="demo">
<div class="left"></div>
<div class="center">
<p>description</p>
<p>description</p>
<p>description</p>
<span>description</span>
</div>
<div class="btn">確認</div>
<div class="btn">取消</div>
</div>
CSS代碼:
.demo{ width: 600px; height: 150px; border: 1px solid #b7b2b7; margin: 30px auto; padding-top: 17px; display: flex; /*設置爲flex佈局*/ justify-content: space-around;
} .demo > div{ flex: none;
}
4. 固定百分比佈局:
HTML代碼:
<div class="demo">
<div class="item item1"></div>
<div class="item item2"></div>
<div class="item item3"></div>
<div class="item item4"></div>
</div>
(1) 等分佈局:
CSS代碼:
.demo{ display: flex;
} .item{ flex: 1;
}
(2)某一個固定
CSS代碼:
.demo{ display: flex;
} .item{ flex: 1;
} .item2{ flex: 0 0 50%;
}
(3)某兩個固定
CSS代碼:
.demo{ display: flex;
} .item{ flex: 1;
} .item2{ flex: 0 0 50%;
} .item4{ flex: 0 0 20%;
}
(4)三個固定
CSS代碼:
.demo{ display: flex;
} .item{ flex: 1;
} .item1{ flex: 0 0 10%;
} .item2{ flex: 0 0 50%;
} .item4{ flex: 0 0 20%;
}
5. 聖盃佈局,如圖所示
HTML代碼:
<div class="demo">
<div class="header">頭部</div>
<div class="body">
<div class="left">left</div>
<div class="center">center</div>
<div class="right">right</div>
</div>
<div class="footer">底部</div>
</div>
CSS代碼:
.demo{ display: flex; flex-direction: column;
} .demo div{ flex: 1;
} .body{ display: flex;
} .header,.footer,.left,.right{ flex: 0 0 20%!important;
}
6. 輸入框佈局,有時須要在輸入框的前部添加提示,或者後部添加按鈕,如圖所示:
HTML代碼:
<div class="demo">
<span class="tip"></span>
<input type="text" name="" />
<button>search</button>
</div>
CSS代碼:
.demo{ display: flex;
} input{ flex:1;
}
7. 底部footer固定在底部,可是不是fixed定位
頁面會常常用到固定的底欄,可是當頁面內容過少時,footer會到頁面中間,下面用flex來解決
HTML代碼:
<div class="demo">
<div class="main">這是主要內容</div>
<div class="footer">這是底部</div>
</div>
CSS代碼:
.demo{ display: flex; flex-direction: column;
} .main{ flex: 1;
} .footer{ width: 100%; height: 120px;
}
8. 流式佈局 ,以下如所示:
HTML代碼以下:
<div class="demo">
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
</div>
CSS代碼:
.demo{ width: 258px; height: 300px; display: flex; flex-wrap: wrap; align-content: flex-start;
} .item{ flex: 0 0 33.333333%; height: 80px; box-sizing: border-box;
}
參考文檔:http://www.ruanyifeng.com/blog/2015/07/flex-examples.html
by新手小白的紀錄