百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>CSS教程> css中margin-top或者margin-bottom失效
分享本文到:

css中margin-top或者margin-bottom失效

发布时间:01/15 来源: 浏览: 关键词:
css中margin-top是设置容器的外间距了距离了,但有朋友会发现div嵌套后,margin-top或者margin-bottom失效了,下面来看看此问题解决办法。


设计页面的时候遇到一个神奇的问题,下面是html的代码

<body>
   <div class="homeNav">
      <div class="homeCategory  ">
      </div>   
   </div>
</body>

此时我设置子容器homeCategory的样式:


.homeCategory{
   margin-top:30px;
}
发现margin相对的父容器搞错了,找到body去了,成了相对于body来设置margin,此时设置了homeNav 的高度和宽度都没效果,让我抓狂不已,div都不听话了,调试了半天终于找到了原因。

原因:

在两个嵌套的div,如果外层div的父容器padding值为0,
那么内层div的margin-top或者margin-bottom的值会”转移”给外层div,也就是父容器的父容器。

解决办法:

1:设置父容器的的样式加上:overflow:hidden。
2:把对父容器的margin-top外边距改成padding-top内边距。
3:给父容器div加样式, padding-top: 1px。
4:给父容器div加样式,position: absolute。
5:把父元素变成一个 block formating context ,下面是可选的方法
a、float: left/right
b、position: absolute
c、display: inline-block/table-cell
d、overflow: hidden/auto

我自己使用的是第一种方法,建议方法1。

责任编辑:
打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有2人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

订阅获得更多模板