CSS頁面居中

一、水平居中

在實際開發中,我們經常會需要將一個元素水平居中,有如下三種方法可以實現。

1、text-align:center

.parent {
  text-align: center;
}
.child {
  display: inline-block;
}

在父元素中設置text-align:center,在子元素中設置display:inline-block,即可使子元素水平居中。

2、margin:auto

.parent {
  position: relative;
}
.child {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

這種方法需要將子元素設置為絕對定位,然後通過將左邊距設置為50%,再通過transform屬性向左移動自身寬度一半的距離,使子元素水平居中。

3、flex布局

.parent {
  display: flex;
  justify-content: center;
}
.child {
  /* 可以省略 */
}

使用flex布局,將父元素設為flex容器,設置justify-content屬性為center即可使子元素水平居中。

二、垂直居中

同樣地,我們也需要將一個元素垂直居中,有如下三種方法可以實現。

1、line-height

.parent {
  height: 200px;
  line-height: 200px;
}
.child {
  display: inline-block;
  vertical-align: middle;
}

在父元素中設置height和line-height為相同的值,再將子元素設置為inline-block,然後通過vertical-align屬性設置為middle,即可使子元素垂直居中。

2、position+transform

.parent {
  position: relative;
}
.child {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

同樣也需要將子元素設置為絕對定位,將上邊距設置為50%,再通過transform屬性向上移動自身高度一半的距離,使子元素垂直居中。

3、flex布局

.parent {
  display: flex;
  justify-content: center;
  align-items: center;
}
.child {
  /* 可以省略 */
}

使用flex布局,將父元素設為flex容器,設置align-items屬性為center即可使子元素垂直居中。

三、水平垂直居中

如果想要將一個元素水平垂直居中,可以結合以上方法進行實現。

1、position+transform

.parent {
  position: relative;
}
.child {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

將子元素設置為絕對定位,將左邊距和上邊距分別設置為50%,再通過transform屬性向上和向左移動自身寬高的一半距離,即可使子元素水平垂直居中。

2、flex布局

.parent {
  display: flex;
  justify-content: center;
  align-items: center;
}
.child {
  /* 可以省略 */
}

設置父元素為flex容器,同時將justify-content和align-items屬性都設置為center,即可實現水平垂直居中。

原創文章,作者:FXZOM,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/335048.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FXZOM的頭像FXZOM
上一篇 2025-02-05 13:05
下一篇 2025-02-05 13:05

相關推薦

  • 打包後頁面空白的解決方案

    當我們在調試階段時,我們的app可能看起來完美無缺,但當我們進行打包時,在運行app時,我們可能會遇到白屏或空白的問題。在這篇文章中,我們將探討如何解決這種問題。 一、檢查文件路徑…

    編程 2025-04-29
  • Python操作Web頁面

    本文將從多個方面詳細介紹Python操作Web頁面的技巧、方法和注意事項。 一、安裝必要的庫 在Python中操作Web頁面,需要用到一些第三方庫。 pip install req…

    編程 2025-04-28
  • CSS sans字體家族

    CSS sans字體家族是一組基於CSS的無襯線字體,具有在不同設備和瀏覽器上保持一致的特性。本文將從優勢、使用、自定義等多個方面對CSS sans字體家族進行詳細介紹。 一、優勢…

    編程 2025-04-28
  • PHP登錄頁面代碼實現

    本文將從多個方面詳細闡述如何使用PHP編寫一個簡單的登錄頁面。 1. PHP登錄頁面基本架構 在PHP登錄頁面中,需要包含HTML表單,用戶在表單中輸入賬號密碼等信息,提交表單後服…

    編程 2025-04-27
  • CSS教程:從入門到精通

    一、CSS是什麼 CSS(Cascading Style Sheets)是一種用於定義網頁樣式的語言。由於網頁內容和樣式是分開保存的,因此CSS可以使設計者和開發者分離出樣式與內容…

    編程 2025-04-25
  • SVG與CSS

    一、SVG與CSS的介紹 SVG(可縮放矢量圖形)是用於描述二維矢量圖形的XML標記語言。其可以通過文本編輯器進行編輯,也可以通過JavaScript動態操作SVG元素。與常規圖像…

    編程 2025-04-25
  • 用vuefavicon管理你的頁面icon標籤

    一、什麼是vuefavicon vuefavicon是一種Vue.js插件,用於動態管理網站的favicon圖標。通常情況下,我們會將網站的icon標籤放置在html文檔的head…

    編程 2025-04-25
  • HTML編寫登錄註冊頁面

    一、HTML做一個登錄註冊頁面簡約 簡約風格一直是大家喜歡的設計風格,下面我們就從簡約風格角度來看HTML如何編寫登錄註冊頁面。 一個簡約的登錄註冊頁面不需要複雜的線條和花哨的背景…

    編程 2025-04-25
  • CSS 事件穿透

    在 Web 開發中,CSS 負責網頁的樣式,而 JavaScript 負責網頁的行為。雖然兩者有不同的職責,但在實際的開發過程中,我們經常會遇到將二者結合起來的場景。比如需要通過 …

    編程 2025-04-25
  • CSS投影的全面解析

    一、投影簡介 CSS投影是指在HTML元素周圍創建出一種類似於投影的效果,從而增強元素的立體感和深度感。投影可以幫助設計師和開發人員在設計頁面時提升視覺效果,提高頁面的可讀性和易用…

    編程 2025-04-24

發表回復

登錄後才能評論