亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

絕對定位+平移實現居中布局

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 函數的百分比是相對于自身;
  • 不僅適用于未知寬高,也同樣適用于固定寬高的居中布局。