CSS中margin-top屬性失效問題解決
CSS屬性有很多值得學習的地方,你對CSS中margin-top屬性失效的解決方法是否熟悉,這里和大家分享一下,相信通過本文的介紹你對margin-top屬性失效的解決方法一定會有深刻的認識。
關于margin-top屬性失效的解決方法
常出現兩種情況:
(一)margin-top失效
先看下面代碼:
- <div>
- <divclassdivclass="box1">float:left</div>
- <divclassdivclass="box2">clear:both;margin-top:20px;</div>
- </div>
兩個層box1和box2,box1具有浮動屬性,box2沒有,這時候設置box2的上邊距margin-top沒有效果。
網上能找到的兩種比較靠譜的解釋:
1:“在CSS2.1中,水平的margin不會被折疊;垂直margin可能在一些盒模型中被折疊…”
2:當***個層浮動,而第二個沒浮動層的margin會被壓縮,詳見--浮動元素后非浮動元素的margin的處理。
得到解決問題思路:要浮動一起浮動,要就一起不浮動。
解決辦法:
1.box2增加float屬性
2.box1與box2之間增加一層"<divstyle="clear:both;"></div>"
(二)子元素設置margin-top作用于父容器
- <divclassdivclass="box"style="height:100px;background:red;">
- <divclassdivclass="box2">clear:both;
- margin-top:20px;height:50px;width:500px;
- background:#000;</div>
- </div>
當給box2設置margin-top時,在FF下僅作用于父容器。
解決辦法:
1.給父容器box加overflow:hidden;屬性
2.父容器box加border除none以外的屬性
3.用父容器box的padding-top代替margin-top
【編輯推薦】