margin-top失效, css + div 布局之 CSS盒模型 外边距合并问题

问题表述:
那天晚上一个同学给我发来一个问题,原型大概是“一个maindiv嵌套了一个div.class="headr1" 的div 和一个div.class="header2" 的这样两个 div,他给maindiv 设定了background="black" header1设定background=“red” 。header2 设定background=“blue” 同时给heder1 设定margin-top:10px; 他预想的是内层 div.heder1 的上边距 maindiv 上边有10px的距离 但事实上 出现一个问题   ,内层div 并没有出现他所预想的那种效果,实际效果是 maindiv 仍然紧贴内层div 整个maindiv 上边框距离浏览器上边 增加了10px 的外边距”
问题页面代码:
复制代码
 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  2 <html xmlns="http://www.w3.org/1999/xhtml">  3 <head>  4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />  5 <title>无标题文档</title>  6 <style type="text/css">  7 *{  8 margin:0;  9 padding:0; 10 } 11 #maindiv{ 12  13 width:800px; 14 height:800px; 15 background-color:#00FFFF; 16 <!-- overflow:hidden; --> 17  18 } 19 .header1{ 20 width:600px; 21 height:100px; 22 margin-top:80px; 23 background-color:#FF0000; 24 overflow:hidden; 25  26 } 27 .header2{ 28 border: 1px solid #00FFFF; 29 width:600px; 30 height:100px; 31 margin-top:20px; 32 background-color:#666666; 33 overflow:hidden; 34  35 } 36 </style> 37 </head> 38  39 <body> 40 <div id="maindiv"> 41   <div class="header1">  42  新华网马尼拉4月23日电(记者赵洁民)中国驻菲律宾大使馆发言人张华23日对媒体说, 43 中国并非如某些人所说的那样,正使中菲在南海黄岩岛的紧张局势升级,而是正使那里的局势降级。 44 张华说,中国在黄岩岛海域的渔政310船和海监船084号22日已离开黄岩岛海域。目前, 45 只有一艘海监船仍在黄岩岛海域执法。他指出:“中国撤出两艘舰船再一次证明,中国并非如某些人说的那样, 46 正使黄岩岛的紧张局势升级,而是使那里的局势降级。” 47 这位发言人的谈话是针对菲律宾一些媒体关于“中国正在使黄岩岛局势升级”的误导。 48 张华强调,中国愿意通过外交手段友好解决这一事件。 49     </div> 50   <div class="header2"> 51 新华网马尼拉4月23日电(记者赵洁民)中国驻菲律宾大使馆发言人张华23日对媒体说, 52 中国并非如某些人所说的那样,正使中菲在南海黄岩岛的紧张局势升级,而是正使那里的局势降级。 53 张华说,中国在黄岩岛海域的渔政310船和海监船084号22日已离开黄岩岛海域。目前, 54 只有一艘海监船仍在黄岩岛海域执法。他指出:“中国撤出两艘舰船再一次证明,中国并非如某些人说的那样, 55 正使黄岩岛的紧张局势升级,而是使那里的局势降级。” 56 这位发言人的谈话是针对菲律宾一些媒体关于“中国正在使黄岩岛局势升级”的误导。 57 张华强调,中国愿意通过外交手段友好解决这一事件。 58 </div> 59 </div> 60  61 </body> 62  63 </html>
问题页面效果如图:


在该页面中
<!-- overflow:hidden; --> 被注释掉了,此时页面显示的效果是问题描述的效果,上边有空出一大块,最外层的DIV也跟着加了80px外边距。如果把这句去掉则是我的那个同学预想的效果。
这个也是我在查阅文档以及上网求助后找到的一个解决方法。这个问题被归结为"外边距合并问题" 。
问题产生的原因:

在经过我用谷歌浏览器的查看DOM 结果后我发现还是因为一些浏览器的代码渲染差别造成的,我就到http://w3school.com.cn/ 上寻求解释。终于在这里


我看出了问题的存在(盒子没有获得 haslayout  造成 margin-top无效),我到百度上又搜索了一下别人是不是也遇到了同样的问题,综合各家说法我最后总结出以下几个问题的重点:

  1. 在常规文档流中,2个或以上的块级盒模型相邻的垂直margin会被折叠。最终的margin值计算方法如下:
    a、全部都为正值,取最大者;
    b、不全是正值,则都取绝对值,然后用正值减去最大值;
    c、没有正值,则都取绝对值,然后用0减去最大值。
    注意:相邻的盒模型可能由DOM元素动态产生并没有相邻或继承关系。
  2. 相邻的盒模型中,如果其中的一个是浮动的(floated),垂直margin不会被折叠,甚至一个浮动的盒模型和它的子元素之间也是这样。
  3. 设置了overflow属性的元素和它的子元素之间的margin不会被折叠(overflow取值为visible除外)。
  4. 设置了绝对定位(position:absolute)的盒模型,垂直margin不会被折叠,甚至和他们的子元素之间也是一样。
  5. 设置了display:inline-block的元素,垂直margin不会被折叠,甚至和他们的子元素之间也是一样。
  6. 如果一个盒模型的上下margin相邻,这时它的margin可能折叠覆盖(collapse through)它。在这种情况下,元素的位置(position)取决于它的相邻元素的margin是否被折叠。
    a、如果元素的margin和它的父元素的margin-top折叠在一起,盒模型border-top的边界定义和它的父元素相同。
    b、另外,任意元素的父元素不参与margin的折叠,或者说只有父元素的margin-bottom是参与计算的。如果元素的border-top非零,那么元素的border-top边界位置和原来一样。
    一个应用了清除操作的元素的margin-top绝不会和它的块级父元素的margin-bottom折叠。
    注意,那些已经被折叠覆盖的元素的位置对其他已经被折叠的元素的位置没有任何影响;只有在对这些元素的子元素定位时,border-top边界位置才是必需的。
  7. 根元素的垂直margin不会被折叠。
解决方案:
  • 在父层div加上:overflow:hidden;
  • 把margin-top外边距改成padding-top内边距;
  • 父元素产生边距重叠的边有不为 0 的 padding 或宽度不为 0 且 style 不为 none 的 border
    父层div加: padding-top: 1px;
    让父元素生成一个 block formating context,以下属性可以实现
  •  * float: left/right
  •  * position: absolute
  •  * display: inline-block/table-cell(或其他 table 类型)
  •  * overflow: hidden/auto
  • 父层div加:position: absolute;

就此截住!

注:本文的总结也是网上其他前辈的辛劳我这里知识借用了一下,在此做出声明:我参考的博文地址有:
http://blog.sina.com.cn/s/blog_6bec36f9010110w9.html

http://hi.baidu.com/jmtbai/blog/item/a91a136ca2d098eb42169456.html

还有一点是我觉得有必要说一下的就是这个效果在IE里面出现在谷歌里面不出现,我找到了一点资料是关于IE浏览器关于渲染的原理:
hasLayout:http://baike.baidu.com/view/2945869.htm

转载于:https://www.cnblogs.com/vingi/articles/2575672.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以提供一些指导和建议来制作一个学校的主页,使用CSS DIV布局。 首先,你需要了解CSS DIV布局基本的思路和概念。CSS中的DIV是一个可以用于包含HTML元素的容器,可以被用来组织和布局网页内容。通过设置DIV的属性和样式,可以控制和调整网页布局,包括位置、大小和样式等。 接下来,你可以开始构建你的学校主页。首先,你需要设计一个基本的网页框架,包括页眉、页脚和主要内容区域。然后,你可以将页面划分为若干个DIV区域,用于包含不同的内容和元素,例如菜单、图片、文字等。根据需要,你可以设置DIV的属性和样式,例如位置、宽度、高度、边框、颜色、背景等。 以下是一些CSS DIV布局的示例代码。 HTML代码: ``` <!DOCTYPE html> <html> <head> <title>学校主页</title> <style> /* 页眉 */ .header { background-color: #333; color: #fff; padding: 10px; text-align: center; } /* 菜单 */ .menu { background-color: #f5f5f5; border: 1px solid #ccc; margin: 10px; padding: 10px; text-align: center; } /* 图片 */ .picture { border: 1px solid #ccc; margin: 10px; padding: 10px; text-align: center; } /* 文字 */ .text { border: 1px solid #ccc; margin: 10px; padding: 10px; } /* 页脚 */ .footer { background-color: #333; color: #fff; padding: 10px; text-align: center; } </style> </head> <body> <div class="header"> <h1>欢迎来到学校主页</h1> </div> <div class="menu"> <h2>菜单</h2> <ul> <li><a href="#">首页</a></li> <li><a href="#">学生信息</a></li> <li><a href="#">教师信息</a></li> <li><a href="#">课程信息</a></li> </ul> </div> <div class="picture"> <img src="http://example.com/school.jpg" alt="学校图片"> </div> <div class="text"> <h2>学校简介</h2> <p>这里是学校的简介。我们提供高质量的教学和培训服务,帮助学生取得优异成绩。</p> </div> <div class="footer"> <p>版权所有 © 2021 学校名称</p> </div> </body> </html> ``` 在上面的示例代码中,我们定义了五个DIV区域,分别是页眉、菜单、图片、文字和页脚。通过设置不同的样式和属性,我们可以实现不同的布局效果。当然,这只是一个简单的示例,你可以根据具体需求和设计要求进行更加复杂和丰富的页面布局和设计。 希望这些信息对你有所帮助,如果你有其他问题或需要更多信息,可以随时向我提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值