CSS中置中方式總結

來源:互聯網
上載者:User
本文介紹了CSS中的各類置中方式,8種方式的實現方法講解的很詳細,還配有對應的,需要的朋友可以參考下

今天主要談一談CSS中的各種置中的辦法。
首先是水平置中,最簡單的辦法當然就是

複製代碼 代碼如下:

margin:0 auto;

也就是將margin-left和margin-right屬性設定為auto,從而達到水平置中的效果。

那麼其他的辦法呢?容我一一道來:

line-height

首先介紹文字的水平置中方法:

複製代碼 代碼如下:

<p class="wrap">劉放</p>

利用line-height設為height的一樣即可:

複製代碼 代碼如下:

.wrap{
line-height: 200px;/*垂直置中關鍵*/
text-align:center;

height: 200px;
font-size: 36px;
background-color: #ccc;
}

效果如下:

padding填充

利用padding和background-clip配合實現p的水平垂直置中:

複製代碼 代碼如下:

<p class="parent">
<p class="children"></p>
</p>

通過backgroun-clip設定為content-box,將背景裁剪到內容區外沿,再利用padding設為外p減去內p的差的一半,來實現:


.parent{ margin:0 auto; width:200px; height:200px; background-color:red;}.children { width: 100px; height: 100px; padding: 50px; background-color: black; background-clip:content-box;/*置中的關鍵*/

效果如下:

margin填充

接下來介紹margin填充的方式來實現水平垂直置中。
首先我們還是定義父子p:

<p class="parent">
<p class="children"></p>
</p>

這裡我們利用將子p的margin-top設定為父p高度減去子p高度的一半,然後再通過overflow設定為hidden來觸發父p的BFC,LESS代碼如下:


@parentWidth:200px;@childrenWidth:50px;.parent { margin:0 auto; height:@parentWidth; width:@parentWidth; background: red; overflow:hidden;/*觸發BFC*/}.children { height:@childrenWidth; width:@childrenWidth; margin-left:auto; margin-right:auto; margin-top: (@parentWidth - @childrenWidth) / 2; background:black;}

最後得到置中效果如下:

absolute定位

利用position:absolute搭配top,left 50%,再將margin設為負值也可以對p進行水平垂直置中,首先還是需要定義父子p:

複製代碼 代碼如下:

<p class="parent">
<p class="children"></p>
</p>

然後設定相應的css:


.parent { position:relative; margin:0 auto; width:200px; height:200px; background-color:red;}.children { position:absolute;  left:50%;  top:50%;  margin:-25px 0 0 -25px ; height:50px; width:50px; background-color: black;}

其中的margin中的值為該p寬度的一半,最後:

text-align置中

眾所周知,text-align可以使得一個p中的內容水平置中。但是如果是要將該p中的子p置中呢?可以將子p的display設為inline-block。


.parent { text-align:center; margin:0 auto; width:200px; height:200px; background:red;}.children { positiona;absolute; margin-top:75px; width:50px; height:50px; background: black; display:inline-block;/*使其父元素text-align生效*/}

圖片置中

一般的圖片置中都是和text-align一樣,將圖片封裝在一個p中,將該p的text-align設為center即可。
可以參考下面的連結:
個人網站

有一種特殊的方式,利用了一個圖片進行佔位,以讓父容器獲得高寬,從而讓進行-50%位移的圖片能有一個參照容器作百分比計算。優點是可以不知道圖片的大小,隨便放張尺寸不超過父容器的圖片上去都能做到置中。另外,相容性好,IE6都是能順利相容的。代碼如下:

複製代碼 代碼如下:

<p class="parent">
<p>
<img class="hidden-img" src="http://nec.netease.com/img/s/1.jpg" alt="" />
<img class="show-img" src="http://nec.netease.com/img/s/1.jpg" alt="" /></p>
</p>


.parent { position:relative; width:100%; height:200px; background:red;}p { position:absolute; top:50%; left:50%;}.hidden-img { visibility:hidden;}.show-img { position:absolute; right:50%; bottom:50%;}

效果如下:

transform置中

上面講到的p置中的例子中,p的寬度都是固定的,然而實際項目中,有可能遇到不定寬的p,特別是響應式或者移動端的設計中,更加常見。所以下面介紹一種不需要定寬的p水平垂直置中方法。
先上代碼:

複製代碼 代碼如下:

<p class="parent">
<p class="children">
<p class="children-inline">我是水平垂直置中噢!</p>
</p>
</p>


.parent { float: left; width: 100%; height: 200px; background-color: red;}.children { float:left; position:relative; top:50%; left:50%;}.children-inline { position: relative; left: -50%; -webkit-transform : translate3d(0, -50%, 0); transform : translate3d(0, -50%, 0); background-color: black; color:white;}

效果如下:

首先我們利用float,將需要置中的p的父p也就是children的寬度收縮,然後left:50%,將children的左邊與水平中線對齊。這個時候,還沒有真正置中,我們需要將children-inner左移動-50%,這樣就水平置中了。
再來說說垂直方向,先將children的top設為50%,然後其上邊和垂直中線對齊了,同樣,我們需要將children-inner上移動-50%。但是這個50%是計算不出來的,所以我們用到了transform : translate3d(0, -50%, 0);
這個方法非常好用噢。

flex置中

最後來介紹一下CSS3中的display:flex來實現的水平垂直置中的方法。

複製代碼 代碼如下:

<p class="parent">
<p class="children">我是通過flex的水平垂直置中噢!</p>
</p>


html,body{ width: 100%; height: 200px;}.parent { display:flex; align-items: center;/*垂直置中*/ justify-content: center;/*水平置中*/ width:100%; height:100%; background-color:red;}.children { background-color:blue;}

效果如下:

這種方式最為簡便,就是相容性不好,不過隨著時間的前進,各大瀏覽器一定會都相容的。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.