關(guān)于html水平垂直居中的問題小結(jié)

最近遇到很多居中的問題,就花點(diǎn)時(shí)間總結(jié)了一下放在這里,以后找也方便
1.居中文本
<div class="wrap">
我在中間……
</div>
.. height+line-height+text-center(只能居中單行)
.wrap{
width:px;
height:px;
border:px solid red;
text-align: center;
line-height: px;
}
ps:text-align:center只是將元素下面的內(nèi)聯(lián)元素居中顯示
1.2display:table-cell(多行固定高度居中)
.wrap{
width:px;
height:px;
border:px solid red;
text-align: center;
display:table-cell;
vertical-align: middle;
}
display:table-cell:ie67不管用,最好配合display:table;一起用
ie67下:(以后也不用了,不過也放這兒吧)
方法一:(通過em標(biāo)簽高度與父級(jí)等高,所以span和em居中就相當(dāng)于span在父級(jí)居中)
<div class="wrap">
<span>
我在中間…… 我在中間…… 我在中間…… 我在中間……
</span>
<em></em>
</div>
.wrap{
width:px;
height:px;
border:px solid red;
text-align: center;
}
.wrap span{
vertical-align: middle;
display:inline-block;
width:px;
}
.wrap em{
height:%;
vertical-align: middle;
display:inline-block;
}
方法二:(通過給子元素增加一個(gè)絕對(duì)定位的父級(jí)標(biāo)簽,再配合子元素的相對(duì)定位水平垂直居中)
<div class="wrap">
<span class="span">
<span class="span">我在中間…… 我在中間…… 我在中間…… 我在中間……</span>
</span>
</div>
.wrap{
width:px;
height:px;
border:px solid red;
display:table;
position:relative;
overflow: hidden;
}
.wrap .span{
display:table-cell;
vertical-align: middle;
text-align: center;
*position:absolute;
top:%;
left:%;
}
.wrap .span{
*position:relative;
top:-%;
left:-%;
}
1.3padding(內(nèi)填充,不用多說)
.wrap{
width:px;
border:px solid red;
padding:px ;
}
2.居中元素
<div class="wrap">
<span></span>
</div>
2.1position:absolute+margin負(fù)值(必須要有寬高,才能計(jì)算margin)
.wrap{
width:px;
height:px;
position:absolute;
top:%;
left:%;
margin-top:-px;
margin-left:-px;
border:px solid red;
}
.wrap span{
width:px;
height:px;
background:red;
position: absolute;
top:%;
left:%;
margin-top:-px;
margin-left:-px;
}
ps:CSS實(shí)現(xiàn)DIV水平居中和上下垂直居中
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>上下垂直居中 在線演示 DIVCSS5</title>
<style>
#main {
position: absolute;
width:400px;
height:200px;
left:50%;
top:50%;
margin-left:-200px;
margin-top:-100px;
border:1px solid #00F
}
/*css注釋:為了方便截圖,對(duì)CSS代碼進(jìn)行換行*/
</style>
</head>
<body>
<div id="main">DIV水平居中和上下垂直居中<a >DIVCSS5</a></div>
</body>
</html>
水平垂直居中原理介紹
這里使用了絕對(duì)定位position:absolute,使用left和top設(shè)置對(duì)象距離上和左為50%,但如果設(shè)置50%,實(shí)際上盒子是沒有實(shí)現(xiàn)居中效果,所以又設(shè)置margin-left:-200px;margin-top:-100px;,這里有個(gè)技巧是,margin-left的值是寬度一半,margin-top的值也是對(duì)象高度一半,同時(shí)設(shè)置為負(fù),這樣就實(shí)現(xiàn)了水平和垂直居中。
相關(guān)文章
利用CSS3的flexbox實(shí)現(xiàn)水平垂直居中與三列等高布局
這篇文章給大家介紹了三個(gè)小節(jié)的內(nèi)容,其中包括關(guān)于css3中flexbox需要掌握的概念、flexbox實(shí)現(xiàn)水平垂直居中對(duì)齊和三列等高自適應(yīng)頁(yè)腳區(qū)域黏附底部的布局,有需要的可以參考2016-09-12Flexbox制作CSS布局實(shí)現(xiàn)水平垂直居中的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)硪黄狥lexbox制作CSS布局實(shí)現(xiàn)水平垂直居中的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-07-27淺析CSS實(shí)現(xiàn)水平垂直同時(shí)居中的5種思路
下面小編就為大家?guī)硪黄獪\析CSS實(shí)現(xiàn)水平垂直同時(shí)居中的5種思路。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考,一起跟隨小編過來看看吧2016-04-28- 下面小編就為大家?guī)硪黄孌IV水平垂直居中的兩種完美方法推薦。一起跟隨小編過來看看吧。希望給大家一個(gè)參考2016-03-15
- 這篇文章主要介紹了CSS解決頁(yè)面圖片水平垂直居中問題的方法,文中給出了三種方案而無需依賴JavaScript,需要的朋友可以參考下2016-03-10
全面總結(jié)使用CSS實(shí)現(xiàn)水平垂直居中效果的方法
這篇文章主要介紹了使用CSS實(shí)現(xiàn)水平垂直居中效果的方法的總結(jié),涵蓋了從最原始的高度設(shè)置到令人興奮的CSS3的Flexbox方式,非常全面,十分推薦!需要的朋友可以參考下2016-03-10- 這篇文章主要介紹了CSS定位“十字架”之水平垂直居中的相關(guān)資料,CSS如何定位“十字架”實(shí)現(xiàn)水平垂直居中效果,小編為大家解答,感興趣的小伙伴們可以參考一下2016-03-02
- 這篇文章主要針對(duì)HTML對(duì)于元素水平垂直居中進(jìn)行的探討,對(duì)元素水平垂直居中操作進(jìn)行講解,感興趣的小伙伴們可以參考一下2016-02-24
- 這篇文章主要介紹了DIV或者DIV里面的圖片水平與垂直居中的方法,需要的朋友可以參考下2018-11-15