1. 程式人生 > >解決CSS垂直居中的幾種方法(基於絕對定位,基於視口單位,Flexbox方法)

解決CSS垂直居中的幾種方法(基於絕對定位,基於視口單位,Flexbox方法)

       在CSS中對元素進行水平居中是非常簡單的:如果它是一個行內元素,就對它的父元素應用 text-align: center ;如果它是一個塊級元素,就對它自身應用 margin: auto。然而如果要對一個元素進行垂直居中,可能光是想想就令人頭皮發麻了。

  多年以來,垂直居中已經成為了CSS領域的聖盃,它同樣也是前端開發圈內廣為流傳的笑話。原因在於它同時具備以下幾條特徵:

              1)它是極其常見的需求。

              2)從理論上來看,它似乎極其簡單。

              3)在實踐中,它往往難如登天,當涉及尺寸不固定的元素時尤其如此。

      接下來我們具體說明一下這三個方法的簡單使用。

一、程式碼初始化

  我們基於如下這段HTML程式碼,將id='content'的div元素在id='box'的div張垂直居中。

<body>
<div id="box">
    <div id="content">這是要居中的元素</div>
</div>
</body>
     基本樣式如下:
#box{
     margin:0;
     padding:0;
     width:500px;
     height:500px;
     background: #4AC291;
     font-size:100%;
     position: relative;
}
#content{
     background: #655;
     color: white;
     text-align: center;
     line-height: 2em;
}

二、基於絕對定位的解決方法

 如果我們想要利用絕對定位的方法進行垂直劇中的話,那麼就要求元素具有固定的寬度和高度,如果沒有固定的寬度和高度就無法實現,因為需要利用top和left的值,進行定位。

        #box{
            margin:0;
            padding:0;
            width:500px;
            height:500px;
            background: #4AC291;
            font-size:100%;
            position: relative;    //必須的,因為下面的div要根據這個進行定位
        }
        #content{
            background: #655;
            color: white;
            text-align: center;
            line-height: 2em;
            position: absolute;   //設定絕對定位
            top:50%;
            left:50%;
            width:12em;
            height:2em;
            margin-top:-1em;    //    2/2=1
            margin-left:-6em;   //    12/2=6
      }

       如上圖所示,是固定寬高的樣式效果。

  這段程式碼在本質上做了這樣幾件事情:先把這個元素的左上角放置在視口(或最近的、具有定位屬性的祖先元素)的正中心,然後再利用負外邊距把它向左、向上移動(移動距離相當於它自身寬高的一半),從而把元素的正中心放置在視口的正中心。藉助強大的 calc() 函式,這段程式碼還可以省掉兩行宣告:

        #box{
            margin:0;
            padding:0;
            width:500px;
            height:500px;
            background: #4AC291;
            font-size:100%;
            position: relative;
        }
        #content{
            background: #655;
            color: white;
            text-align: center;
            line-height: 2em;
          /*position: absolute;
            top:50%;
            left:50%;
            width:12em;
            height:2em;
            margin-top:-1em;
            margin-left:-6em;*/
            position: absolute;
            width: 12em;
            height: 2em;
            top: calc(50% - 1em);
            left: calc(50% - 6em);
      }

       這個方法最大的侷限在於它要求元素的寬高是固定的。在通常情況下,對那些需要居中的元素來說,其尺寸往往是由其內容來決定的。如果能找到一個屬性的百分比值以元素自身的寬高作為解析基準,那我們的難題就迎刃而解了!遺憾的是,對於絕大多數CSS屬性(包括 margin)來說,百分比都是以其父元素的尺寸為基準進行解析的。

三、基於視口單位的解決方法

    假設我們不想使用絕對定位,仍然可以採用translate()技巧來把這個元素以其自身寬高的一半為距離進行移動;但是在缺少left和top的情況下,如何把這個元素的左上角放置的容器的正中心呢?

   我們的第一反應很可能是用margin屬性的百分比值來實現,就像這樣:

#content {
  width: 12em;
  margin: 50% auto 0;
  transform: translateY(-50%);
}

  這段程式碼產生的效果十分離譜。原因在於margin的百分比值時以父元素的寬度作為解析基準的。沒錯,即使對於margin-top和margin-bottom來說也是這樣!

  不過幸運的是,如果只是想把元素相對於視口進行居中,仍然是有希望的。CSS值與單位(第三版)定義了一套新的單位,稱為視口相關的長度單位。

      1) vw 是與視口寬度相關的。與常人的直覺不符的是,1vw 實際上表示視口寬度的 1%,而不是 100%。

       2)  與 vw 類似,1vh 表示視口高度的 1%。

       3)  當視口寬度小於高度時,1vmin 等於 1vw,否則等於 1vh。

       4)  當視口寬度大於高度時,1vmax 等於 1vw,否則等於 1vh。

四、Flexbox方法(本文主要說明的方法)

      Flexbox(伸縮盒)是專門針對這類需求所設計的。我們之所以要討論其他方案,僅僅是因為那些方案在瀏覽器的支援程度上稍微好一些而已。其實目前現代瀏覽器對 Flexbox 的支援度已經相當不錯了。

  我們只需寫兩行宣告即可:先給這個待居中元素的父元素設定 display: flex(在這個例子中是元素),再給這個元素自身設定我們再熟悉不過的margin: auto。

       #box{
            display: flex;
            min-height:50vh;
            margin:0;
            width:500px;
            height:500px;
            background: #4AC291;
        }
        #content{
            margin:auto;
            background: #655;
            color: white;
        }

  如果瀏覽器不支援Flexbox,頁面渲染結果看起來就跟我們的起點圖是一樣的了(如果設定了寬度的話)。雖然沒有垂直居中效果,但也是完全可以接受的。

  Flexbo 的另一個好處在於,它還可以將匿名容器(即沒有被標籤包裹的文字節點)垂直居中。



相關推薦

css垂直居中方法

play spa light dex bsp png ava ems pre 方法1:table-cell .box1{ display: table-cell; vertical-align: middle; text-a

CSS垂直居中方法

垂直居中佈局很常用到,自己總結下來以後用的話也很方便,算是對自己上網閱讀資料的一個考核 1.不知道自己高度和父容器高度的情況下, 利用絕對定位只需要以下三行: parentElement{ position:relative; } child

解決CSS垂直居中方法基於絕對定位基於單位Flexbox方法

       在CSS中對元素進行水平居中是非常簡單的:如果它是一個行內元素,就對它的父元素應用 text-align: center ;如果它是一個塊級元素,就對它自身應用 margin: aut

css垂直居中方法

Margin:0 auto; 適用於塊狀元素具有寬高。不是用於文字居中。 text-align:center可實現文字居中,vertical-align垂直居中文字;可用於內聯元素的居中 text-align+line-height設定與height同大時,文字會水平垂直居中。

css 垂直居中方法

div idt 浮動 spl head ref 維度 oot .html 1.圖片水平垂直居中 html: <div class="parent"> <div class="child">

css實現垂直居中方式佈局常用

前提: html模板: <div class="parent"> <div class="content">內容垂直居中</div> </div> 宣告:以下示例,主要實現垂直居中的樣式程式碼為加粗的部分 一、對單行

css垂直居中的四方法

center utf-8 borde gre abs ddl for relative eight <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8">

CSS中常用到的一些解決問題方法整理一些真正有效能夠使用到專案中的方法等待不斷更新積累

1.如何強制文字換行 {white-space:normal; width:200px; } 2.高度不固定的div,裡面的文字垂直居中 // 加在父級div中 垂直居中:align-items:center; display: -webkit-flex; 水平居中:justify-co

jq 追加元素的方法append()、prepend()、after()、before()、insertAfter()、insertBefore()

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>js中常用追加元素的幾種方法</title> <link rel

CSS 垂直居中的11方式

11種實現方式分別如下: 1. 使用絕對定位和負外邊距對塊級元素進行垂直居中 html程式碼: <div id="box"> <div id="child">我是測試DIV</div> </div> 複製程式碼:

CSS垂直居中的11實現方式

注:以下demo都只是針對現代瀏覽器所做,未相容低版本的IE以及其它非主流瀏覽器。 11種實現方式分別如下: 1. 使用絕對定位和負外邊距對塊級元素進行垂直居中 html程式碼: <div id="box"> <div id="child">我是測試DIV</div

android app -- 關於listview的用法複用不復用半複用解決item狀態改變的問題

1.從最基本的不復用開始,也就是在Adapter 的getView方法中不使用ViewHolder。 這樣做,也就是在listView上下滑動,被隱藏的項滑出來的時候,每次都重繪一次這一項,這樣的話

CSS垂直居中的三方式

在說垂直居中之前先看一下水平居中,相對於垂直居中來說水平居中就簡單多了:        如果是一個行內元素,就對它的父級直接使用text-align: center;        如果是一個塊級元素,就對它自身

vue開發環境解決跨域的方法

解決方案 解決跨域的方法很多 後端有設定請求   前端有jquery的jsonp、script的請求轉發等,出現跨域問題主要時因為瀏覽器的同源策略,所以只要在中間做個代理請求,就可以巧妙的避開跨域問題 一,使用proxyTable屬性   這裡vue腳手架生成的標準專案

如何讓DIV水平和垂直居中方法

方法1 CSS實現水平和垂直居中 要讓DIV水平和垂直居中,必需知道該DIV得寬度和高度,然後設定位置為絕對位置,距離頁面視窗左邊框和上邊框的距離設定為50%,這個50%就是指頁面視窗的寬度和高度的50%,最後將該DIV分別左移和上移,左移和上移的大小就是該D

解決高併發的方法

一、將資料存到redis快取 二、使用高效能的伺服器、高效能的資料庫、高效率的程式語言、還有高效能的Web容器. 三、使用Ngnix負載均衡 電商如何處理高併發 為了解決高併發訪問量我們採用了Htt

垂直居中方法

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>垂直水平居中</title> </head> <style>

HTML中引入CSS檔案的方法

 概況來說有以下四種:        1.行內式:也稱內聯式,在標記的style屬性中設定CSS樣式。這種方式沒有體現出CSS的優勢;        2.嵌入式:將CSS樣式集中寫在網頁的<he

未知寬高div水平垂直居中3方法

<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> </head> <body> <!--方法1:一個未知寬高的彈出框,水平垂直居中--&

微信小程式文字水平垂直居中對齊問題完美解決方案

我們知道常用的居中對齊方式有很多種例如:text-align:center; align-items:center; justify-content: center; margin: auto; #子