絕對定位+平移實現居中布局
1. 前言
有時中間盒子的內容是要靠后臺傳過來的數據決定的,如果寫死的話,當數據較多時就會發生溢出,數據較少時又會空出一大片,所以我們需要一種更加智能的方式來實現居中布局。
絕對定位 + 平移
是 絕對定位 + 負邊距
的改進版,那么具體都改進了哪些方面呢?
負邊距的百分比并不是相對于自身,而是相對于父元素,所以只能寫具體的像素值,顯得不夠智能。
而平移相對于自身,只需要無腦寫 -50%
就可以了。
2. 實例代碼
來看如何用絕對定位+平移來實現居中布局:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
/* 清除默認樣式 */
* { padding: 0; margin: 0; }
/* 令html和body全屏顯示, 并有一個灰色背景 */
html, body { height: 100%; background: gray; }
/* 先在父元素上設置相對定位 */
body { position: relative }
.center {
/* 絕對定位 */
position: absolute;
/* 上方和左方為50% */
top: 50%;
left: 50%;
/* 不用給寬高,但是可以給個內邊距防止內容與盒子過于貼合 */
padding: 10px;
/* 這個50%是相對于自身寬高而言的 */
transform: translate(-50%, -50%);
/* 白色背景 */
background: white;
}
</style>
</head>
<body>
<div class="center">
用內容撐開盒子
</div>
</body>
</html>
運行結果:
3. 小結
- margin 的百分比是相對于父元素的寬;
- translate 函數的百分比是相對于自身;
- 不僅適用于未知寬高,也同樣適用于固定寬高的居中布局。