關于html水平垂直居中的問題小結
最近遇到很多居中的問題,就花點時間總結了一下放在這里,以后找也方便
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標簽高度與父級等高,所以span和em居中就相當于span在父級居中)
<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;
}
方法二:(通過給子元素增加一個絕對定位的父級標簽,再配合子元素的相對定位水平垂直居中)
<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負值(必須要有寬高,才能計算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實現(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注釋:為了方便截圖,對CSS代碼進行換行*/
</style>
</head>
<body>
<div id="main">DIV水平居中和上下垂直居中<a >DIVCSS5</a></div>
</body>
</html>
水平垂直居中原理介紹
這里使用了絕對定位position:absolute,使用left和top設置對象距離上和左為50%,但如果設置50%,實際上盒子是沒有實現(xiàn)居中效果,所以又設置margin-left:-200px;margin-top:-100px;,這里有個技巧是,margin-left的值是寬度一半,margin-top的值也是對象高度一半,同時設置為負,這樣就實現(xiàn)了水平和垂直居中。
上一篇:canvas.toDataURL image/png 報錯處理方法推薦
欄 目:CSS/HTML
下一篇:HTML基礎必看---表單,圖片熱點,網(wǎng)頁劃區(qū)和拼接詳解
本文標題:關于html水平垂直居中的問題小結
本文地址:http://mengdiqiu.com.cn/a1/CSS_HTML/9655.html
您可能感興趣的文章
- 04-02好看的字體樣式css,好看的字體樣式圖片
- 04-02html中加入css樣式的簡單介紹
- 01-10通過html為FLASH加鏈接的實現(xiàn)代碼(div層)
- 01-10IE瀏覽器HTML Hack標簽總結
- 01-10html用style添加屬性示例
- 01-10HTML中rel屬性分析
- 01-10HTML元素設置焦點的方法
- 01-10在html文件里include文件內(nèi)容的方法小結
- 01-10常用HTML meta 標簽屬性(網(wǎng)站兼容與優(yōu)化需要)
- 01-10用HTML和CSS打造屬于自己的暖男“大白”


閱讀排行
本欄相關
- 04-02表格樣式css樣式,css樣式表單
- 04-02好看的字體樣式css,好看的字體樣式圖
- 04-02分頁樣式css,分頁樣式jq
- 04-02分頁樣式css,分頁樣式欄里用來定義首
- 04-02css樣式的引入,css樣式怎么引入
- 04-02css滾動條樣式,css滾動條的樣式
- 04-02css樣式引入方式有幾種,網(wǎng)頁引入css樣
- 04-02html中加入css樣式的簡單介紹
- 04-02vue中的css樣式布局,vue添加css樣式
- 04-02內(nèi)嵌樣式css,內(nèi)嵌樣式表,內(nèi)部樣式表
隨機閱讀
- 08-05dedecms織夢模板全站調(diào)用收藏數(shù)的方法
- 01-10vue實現(xiàn)分頁加載效果
- 08-05DEDECMS點擊主欄目默認顯示第一個子欄
- 01-10C++實現(xiàn)將數(shù)組中的值反轉
- 01-10C語言打印楊輝三角示例匯總
- 01-11常用的HTML富文本編譯器UEditor、CKEdi
- 08-05dedecms織夢模板編輯文檔的同時自動更
- 01-10C++ 類訪問控制的條件總結
- 08-05織夢dedecms首頁調(diào)用縮略圖為背景
- 01-10bat批處理徹底隱藏文件的方法(使用