首頁 web前端 css教學 關於css水平居中的分析

關於css水平居中的分析

Mar 08, 2017 pm 02:12 PM

水平居中是常用的幾種佈局方式之一。主要分為行內元素的居中,塊元素的居中。塊元素的居中也分為固定寬度的居中,不定寬度的居中。行內元素的居中,使用text-align:center就可以實現,已知寬度的塊元素的居中,使用絕對定位以及設置

margin為寬的一半的負值就可以實現。但是不定寬度的居中比起上面兩種更常用,也更複雜,我們常常需要在分頁的頁碼展示等地方用到不定寬居中,使用起來更方便,下面來研究下常用的幾種塊元素的水平居中。

1.標籤巢狀偏移

實作原理:

聯想到固定寬度的居中的實作:先偏移到螢幕中央,在設定其margin方向偏移寬的一半。那麼能不能想到一種方法,借用這種思路,先偏移50%到螢幕的右半部分,然後在反方向偏移回來?實現起來比較困難的點是不知道這個寬度是多少。又想到只要讓其父寬度和子寬度相等,然後用百分數就可以解決。那麼要怎麼讓其父寬度和字寬度一樣呢?巧借float具有的包裹性:父元素如果漂浮了,並且沒有設定寬高,那麼將盡量包裹子元素。

實作程式碼:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>不定宽度水平居中</title>
    <style>
        body{  
            background-color: #e5da31;  
        }  
        .container{  
            position: absolute;   /*脱离文档流,其宽度将由子元素的宽度决定*/  
            left:50%;  
        }  
        .content{  
            position: absolute;  
            left:-50%;  
            background-color: #2ecc71;  
        }  
    </style>
</head>
<body>
<p class="container">
    <p class="content">标签嵌套</p>
</p>
</body>
</html>
登入後複製

實作效果:

關於css水平居中的分析

優點與缺點:

缺點很明顯,需要自己寫和文件內容無關的標籤,多打了幾行程式碼相容性良好,在ie6+瀏覽器上查看沒有問題


#2.flex-box佈局


實作原理:


先定義一個flex容器,然後設定其內容對齊方式為中間對齊

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>不定宽度水平居中</title>
    <style>
        body {  
            background-color: #e5da31;  
        }  
        .container {  
            display: flex;  /*定义一个flex容器*/  
            justify-content: center;  /*定义容器的空间没有被全部占用时,内容的对其方式*/  
        }  
        .content{  
            background-color: #2ecc71;  
        }  
    </style>
</head>
<body>
<p class="container">
    <p class="content">标签嵌套</p>
</p>
</body>
</html>
登入後複製

實作效果:

關於css水平居中的分析


優缺點分析:

實作起來最簡單,但是呢,因為flex的相容性不好,當要相容低階瀏覽器時慎重使用。


3.內嵌佈局


實作原則:

text-align:center可以讓行內元素水平居中,如果改變塊元素為行內元素,在使用text-align就可以實現水平居中。

實作程式碼:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>不定宽度水平居中</title>
    <style>
        body{  
            background-color: #e5da31;  
        }  
        .container{  
          text-align:center;  
        }  
        .content{  
        display: inline;  
            background-color: #2ecc71;  
        }  
    </style>
</head>
<body>
<p class="container">
    <p class="content">标签嵌套</p>
</p>
</body>
</html>
登入後複製

實現效果:

關於css水平居中的分析

優缺點分析:

用原本是修飾文字對齊方式的text-align來實現水平居中總感覺有點彆扭,這塊外面的container也先多餘,但是為了不影響body內其他元素的局部,暫且如此。另外相容性不錯,在ie6+可以正常顯示。

以上就是小編為大家帶來的關於css水平居中的小小探討全部內容了,希望大家多多支持PHP中文網~


#

以上是關於css水平居中的分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

VUE 3 VUE 3 Apr 02, 2025 pm 06:32 PM

它的出局!恭喜Vue團隊完成了完成,我知道這是一項巨大的努力,而且很長時間。所有新文檔也是如此。

您可以從瀏覽器獲得有效的CSS屬性值嗎? 您可以從瀏覽器獲得有效的CSS屬性值嗎? Apr 02, 2025 pm 06:17 PM

我有人寫了這個非常合法的問題。 Lea只是在博客上介紹瞭如何從瀏覽器中獲得有效的CSS屬性。那樣的是這樣。

在CI/CD上有點 在CI/CD上有點 Apr 02, 2025 pm 06:21 PM

我說的“網站”比“移動應用程序”更合適,但我喜歡Max Lynch的框架:

帶有粘性定位的堆疊卡和一點點的雜物 帶有粘性定位的堆疊卡和一點點的雜物 Apr 03, 2025 am 10:30 AM

前幾天,我發現了科里·金尼文(Corey Ginnivan)網站上的這一點,當您滾動時,彼此之間的卡片堆放集。

在WordPress塊編輯器中使用Markdown和本地化 在WordPress塊編輯器中使用Markdown和本地化 Apr 02, 2025 am 04:27 AM

如果我們需要直接在WordPress編輯器中向用戶顯示文檔,那麼最佳方法是什麼?

比較瀏覽器的響應式設計 比較瀏覽器的響應式設計 Apr 02, 2025 pm 06:25 PM

這些桌面應用程序中有許多目標是同時在不同的維度上顯示您的網站。因此,例如,您可以寫作

為什麼Flex佈局中的紫色斜線區域會被誤認為是'溢出空間”? 為什麼Flex佈局中的紫色斜線區域會被誤認為是'溢出空間”? Apr 05, 2025 pm 05:51 PM

關於Flex佈局中紫色斜線區域的疑問在使用Flex佈局時,你可能會遇到一些令人困惑的現象,比如在開發者工具(d...

如何將CSS網格用於粘頭和頁腳 如何將CSS網格用於粘頭和頁腳 Apr 02, 2025 pm 06:29 PM

CSS網格是一系列屬性的集合,旨在使佈局比以往任何時候都容易。像任何東西一樣,那裡有一點學習曲線,但是網格是

See all articles