正確的使用margin:0auto與body{text-align:center;}實現元素居中_Div+CSS教程
教程Tag:暫無Tag,歡迎添加,賺取U幣!
昨天深夜的時候,有朋友在MB5U.com/ask提出一個問題:body{text-align:center}與margin:0 auto的異同?這是一個對齊上的迷惑,剛開始的時候或許大家對它們都不是很理解。我們通過下面的一些小例子來了解他們到底有什么區別,應該在什么樣的情形下正確的使用body{text-align:center}與margin:0 auto。我們首先了解一下它們的基本概念:
text-align是用于設置或對象中文本的對齊方式。一般情況下我們設置文本對齊方式的時候需要用此屬性進行設置,如:
示例代碼 [www.zhaotila.cn]
div { text-align: left; } 表示文本居左對齊。
margin是設置對象四邊的外延邊距,被稱為外補丁或外邊距。如:
示例代碼 [www.zhaotila.cn]
div { margin: 20px 10px 30px 40px; }
表示對象外邊距,頂20px、右10px、下30px、左40px。
表示對象外邊距,頂20px、右10px、下30px、左40px。
我們設置某個對象水平方向居中的時候,經常將左右的外邊距設置為auto來實現。如:
示例代碼 [www.zhaotila.cn]
div { margin: 0 auto; }
現在的問題是:body{text-align:center}與margin:0 auto的異同。text-align:center設置為文本或img標簽等一些內聯對象(或與之類似的元素)的居中。margin:0 auto是設置塊元素(或與之類似的元素)的居中。但這兩個屬性IE與FF的理解也有所不同。
我們設置一個段落P,在段落內存在一個圖片img標簽。
我們設置body{text-align:center;}。得到下面的圖片:


在IE中,段落P,圖片img同時實現了居中對齊,也就是說text-align:center;同時作用于元素p與元素img。
在FF中,段落P,沒有能實現居中對齊,而圖片img實現了居中對齊,也就是說text-align:center;作用于img標簽,而段落p標簽沒有起到居中的作用。
我們設置段落 p {margin:0 auto;}。得到下面的圖片:


我們發現在IE與FF中,段落P均實現了居中對齊。圖片img由于不是作用對象,所以不會居中對齊。
有三種情況需要說明:
一、有朋友在操作的時候,將margin:0 auto;的選擇器混淆了,應該是作用對象,如div,p,而不是body。假如設置:body { margin:0 auto; }將不會達到任何效果,除非你定義body的寬度,那將會讓body內的元素產生位置變化。如我們設置body寬度為500px。對p段落不作任何設置,我們最大化窗口將會看到段落并非處于窗口的最左上角。
二,我們設置段落 p {text-align:center;} 將要實現的并不是段落本身的對齊方式,而是段落內元素居中對齊。
三,我們設置圖片標簽img {margin:0 auto;} ,我們就犯了一個小錯誤,img類于內聯對象,不可以設置圖片img標簽的margin屬性,假如你一定想要設置,那么首先要將它的屬性轉變為塊元素,如下面的代碼:img {display:block; margin:0 auto;}
有朋友產生疑問了,那該如何使用呢?說說我的建議:
假如頁面中的元素,均位于div標簽或其它塊元素內,進行了合理的嵌套,我們不必設置body{text-align:center}。只需要設置相應的div元素margin:0 auto;即可。如上面的代碼所講述,頁面中的元素均位于段落p標簽中,只需要將段落居中即可。
假如頁面中的元素,有一部分不是在div標簽或其它塊元素內,我們需要設置body{text-align:center}。但也會碰到問題,這樣設置以后,大部分內聯元素,都居中對齊了,包括頁面中其它的一些文本,還需要進行相應的調整才能適應設計的需要。如:我們設置body內有一個段落P,在段落內有一個圖片img及一段文本,在body內還存在一個獨立的圖片img,看下面的圖片:

我們實現了段落p的居中,同時也讓位于段落外的圖片實現了居中,但段落中的圖片與文本居中對齊了。如下是運行代碼:
代碼調試框 [www.zhaotila.cn][ 可先修改部分代碼 再運行查看效果 ]
相關Div+CSS教程:
- 相關鏈接:
- 教程說明:
Div+CSS教程-正確的使用margin:0auto與body{text-align:center;}實現元素居中
。