說到水平居中,你們可能以爲很簡單啊,text-align:center 就OK了。css
可是,有時候會發現這樣寫了也沒出效果。緣由是什麼呢? 請往下看。html
水平居中:分爲塊級元素居中和行元素居中web
行內元素:spa
行內元素就是內聯元素。例如<span>、<a>、<label>、<em>、<img>等。。code
直接構建一個具備 」text-align:center「樣式的容器,那麼裏面包含的行內元素就會都居中了。orm
<div style="text-align:center;border-style:solid"> <p style="border-style:solid">我是塊級元素,我不居中</p> <span style="border-style:solid">我是行內元素,我要居中</span> </div>
效果如圖:htm
有沒有發現不對,塊級元素怎麼「看起來」也居中了?給<p>加上寬度後:blog
<div style="text-align:center;border-style:solid"> <p style="border-style:solid;width:500px">我是塊級元素,我不居中</p> <span style="border-style:solid">我是行內元素,我要居中</span> </div>
效果如圖:get
原來只是裏面的文本居中了!it
塊級元素:
塊級元素有:div , p , form, ul, li , ol, dl, form, address, fieldset, hr, menu, table
你們都知道塊級元素是能夠設置height和width的,那麼這就又
分爲定寬與不定寬。
定寬:
定寬其實很好解決。直接margin:0 auto就能夠實現容器居中,再加上text-align:center纔可讓文本居中。
<p style="border-style:solid;text-align:center;margin:0 auto;width:500px">我是定寬塊級元素,我要居中</p>
效果如圖:
不定寬:
不定寬實際上是用的最多的,如這種導航欄:
由於導航欄中的內容是會變化的,因此寬度就不能定死了。要居中的話有三種方法,其中一種是利用table標籤的特性,感受適用性不是很好就不介紹了。
一、直接把元素改成行內元素,既display:inline,而後就能夠用text-align:center了。可是這樣width和height就不能設置了。
css:
.container{
text-align:center;
}
.container ul{
list-style:none;
padding:0;
display:inline;
}
.container li{
margin-right:8px;
border-style: solid;
display:inline;
}
body:
<div class="container"> <ul> <li><a href="#">1</a></li> <li><a href="#">2</a></li> <li><a href="#">3</a></li> </ul> </div>
效果下:
二、下面使用父級元素浮動和相對定位以及lelf:50%。子元素照樣設置但left:-50%。
整改後的css代碼:
.container ul{
list-style:none;
float: left;
position: relative;left: 50%;
padding:0;
}
.container li{
margin-right:8px;
float: left;
position: relative;left:-50%;
}
效果是同樣的,就不貼圖了。(首先,ul設置左浮動是爲了 使得ul的寬度不是100%,而是 幾個li寬度的總和。 以後ul相對定位 使用left把ul移動到劇中位置。由於相對定位是以原來的位置爲原點的,因此先總體移動中間,這樣子ul元素的左邊是中心線,那麼裏面ul裏面的li只要left:-50% 或者right:50%就居中了)
關於浮動能夠參考這篇文章:http://www.th7.cn/web/html-css/201401/17089.shtml
CSS3新特性實現起來更方便:http://www.cnblogs.com/zuochengsi-9/p/7659489.html