外边距合并_html/css_WEB-ITnose

php中文网
发布: 2016-06-24 11:50:25
原创
1696人浏览过

前提 

  只有在普通文档流中垂直相邻外边距会合并。

  行内框,浮动框或者绝对定位之间的外边距不会合并。

 

1.相邻元素有多个外边距

立即学习前端免费学习笔记(深入)”;

1 <ul>2     <li>line 1</li>3     <li>line 2</li>4 </ul>5 <h3>This is h3 line.</h3>
登录后复制

1 ul{margin-bottom:15px;}2 li{margin-top:10px;margin-bottom:20px;}3 h3{margin-top:28px;}
登录后复制

ul下边距为15px,li下边距为20px,h3上边距为28px,外边距合并会取最大值而非相加,由此line 2与h3间距为28px。

注:如果给ul加一个边框,li下边距将被放在ul内部,此时只会发生ul与h3之间的合并。

  如果ul,h3外边距都为负值,则取绝对值最大的负外边距与最大的正外边距相加,得到间距。

 

2.块元素内部包含块元素(父元素没有设置内边距或者边框)

1 <div id="outer">2     <div id="inner"></div>3 </div>
登录后复制

 1  #outer{ 2    width:200px; 3    height:100px; 4    background:rgb(245,138,158); 5    margin-top:20px; 6 } 7 #inner{ 8    width:50px; 9    height:50px;10    background:rgb(147,172,213);11    margin-top:10px;12 }
登录后复制

inner没有预想中的相对outer下沉10px,而是保持和outer位置相对不变,outer整体下沉10px。此时如果设置outer的上外边距为20px,两者相较取其大,整体outer下沉20px。

单元格合并插件tablesMergeCell.js
单元格合并插件tablesMergeCell.js

单元格合并插件tablesMergeCell.js

单元格合并插件tablesMergeCell.js 37
查看详情 单元格合并插件tablesMergeCell.js

如果给父元素加边框(或内边距)隔开内部元素的外边距,则不会发生外边距合并:

 1 #outer{border:1px solid rgb(147,172,213);} 

 注:块元素内包含行内元素的话不会发生外边距合并(见水平居中与垂直居中)。

 

3.空元素的上下外边距合并

1 <div class="blank"></div>2 <div class="focus"></div>3 <div class="blank"></div>
登录后复制

1 .blank{2    width:100px;3    height:50px;4    background:rgb(245,138,158);5 }6 .focus{margin:10px 0 20px 0;}
登录后复制

focus撑开的间距为20px(两者取其大),如果blank有外边距还会继续发生合并,多个空元素同理。

 

参考资料

css外边距合并

详解css外边距合并

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号