关于CSS inline-block、BFC以及外边距合并的几个小问题
CSS inline-block和BCF对于初学者来说,总是弄不太明白,下面记录下我在学习这块知识的过程中遇到的几个问题,供大家参考,有不足的地方,欢迎大家批评指正。
一、在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例
定义:当两个垂直外边距相遇时,将形成一个外边距。
合并的场景:
- 一个元素出现在另一个元素上面时;
示例:

- 一个元素包含另一个元素时(没有内边距或边框把它们的外边距分开)

如图效果中,父容器box和子元素box1的上外边距合并,与子元素box2的下外边距合并。
- 一个没有内边距和边框的空元素,它的上下外边距相遇会合并;

当我们给空元素添加边框后,变化很明显:

我们可以很明显的看到:情况一中文字距离box边框的距离是情况二中的一半。
合并后的高度为这两个外边距中高度为这两个外边距中高度值最大者。
解决方案:
1.对于一个元素出现在另一个元素上面:可以使用的方法有:
- 使用display:inline-block;示例如下:

- 使用浮动;示例如下:

2.对于父子以及空元素外边距合并,可以使用通过设置padding和border来解决;
二、去除inline-block内缝隙有哪几种常见方法?
inline-block产生间隙的情况如下:

要想清除inline-block内的缝隙,我们可以采取以下几种方法:
- 去除li元素之间的空格;示例如下:

- 负边距;示例如下:

注意第一个li与外边界之间的距离。
- 使用浮动;示例如下:

- 将li中的font-size设为0px;示例如下:

三、父容器使用overflow: auto| hidden撑开高度的原理是什么?
父容器使用overflow:auto|hidden后,会形成BFC,清除子元素浮动造成的影响,形成自己的“小宇宙”,从而把父容器撑开。
四、BFC是什么?如何形成BFC,有什么作用?
定义:BFC(Block formating context)直译为“块级格式化上下文”。是按照块级盒子布局的。W3C给出的定义如下:
浮动元素和绝对定位元素,非块级盒子的会计容器(例如inline-blocks,table-cells,和table-captions),以及overflow值不为“visiable”的块级盒子,都会为他们的内容创建新的BFC(块级格式上下文)。
如何形成BFC:
1.根元素或其它包含它的元素;
2.浮动(元素的float 不为none);
3.绝对定位(元素的position 为absolute或fixed);
4.行内块inline-blocks(元素的display:inline-block);
5.表格单元格(元素的display:table-cell,HTML表格单元格默认属性);
6.overflow的值不为visible的元素;
7.弹性盒子flex boxes(元素的display:flex或inline-flex)
作用:
1.BFC可以避免外边距折叠;示例:
html:
<pre><div class="box">
<div class="box1"></div>
<div class="new">
<div class="box2"></div>
</div>
</div></pre>
css:
<pre>.box{
border:1px solid;
background:#ccc;
}
.box1{
height:100px;
width:100px;
background:#0000ff;
margin:20px;
}
.box2{
height:100px;
width:100px;
background:red;
margin:20px;
}
.new{
overflow:auto;
}</pre>
实现的效果:

2.BFC包含浮动;
3.使用BFC避免文字环绕;
4.在多列布局中使用BFC。
五、浮动导致的父容器高度塌陷指什么?为什么会产生?有几种解决方法?
浮动导致的父容器高度塌陷指的是子元素浮动后使得父容器没有高度;
产生原因:浮动的框会左右移动,直至它的边缘遇到包含框或者另一个浮动框的边缘。浮动框或脱离文档流,当一个元素浮动之后,文档流就表现得和浮动框不存在一样,当浮动框高度超过包含框的时候,就会出现包含框不会自动伸高来闭合浮动元素,从而出现“父容器高度塌陷”。
解决方法:
1.使用clear:left|right|both;
2.父元素也设置浮动;
3.给父元素设置overflow:hidden|auto
4.使用伪元素 :after.
参考文献:
1.How To Clear Floats Without Structural Markup
2.那些年我们一起清除过的浮动
3.【CSS】浮动和它的工作原理?清除浮动的技巧?
4.CSS中的BFC
版权所有,若有转载,请注明来源。
关于CSS inline-block、BFC以及外边距合并的几个小问题的更多相关文章
- CSS min-height不能解决垂直外边距合并问题
垂直外边距合并有一种情况是嵌套元素的垂直外边距合并,当父级元素没有设定外边距时,在顶部或者底部边缘的子元素的垂直外边距就会和父级的合并,导致父级也有了“隐形”的垂直外边距. 当父级元素的min-hei ...
- BFC 以及 外边距合并问题
BFC定义: BFC(Block formatting context)直译为"块级格式化上下文". 它是一个独立的渲染区域,只有Block-level box参与, 它规定了内部 ...
- css盒子模型、垂直外边距合并
css盒子模型由四部分组成:内容(content).填充(padding).边框(border).边距(margin),其中css样式中定义的width属性是定义内容区域的宽度,正常情况下,设置了内容 ...
- 深入理解BFC和外边距合并(Margin Collapse)
一.什么是BFC? 1.BFC的概念 BFC全称Block Formatting Context ,直译“块级格式化上下文”,也有译作“块级格式化范围”.它是 W3C CSS 2.1 规范中的一个概念 ...
- css外边距合并和z-index的问题
参考这篇文章, 将外边距的 折叠 参考这篇文章, 将bfc的生成, bfc的应用 参考这篇文章 position: absolute的元素, 仍然具有内填充padding和border边框属性样式, ...
- 李洪强和你一起学习前端之(6)css行高,盒模型,外边距
李洪强和你一起学习前端之(6)css行高,盒模型,外边距 复习昨天的知识 1.1css书写位置: 内嵌式写法 外联式写法 <link href = "1.css" rel = ...
- CSS外边距合并&块格式上下文
前言问题Margin Collapsing 外边距合并Block Formatting Context 块格式化上下文解决方案参考 前言 之前在前端开发的过程中,都没有遇到外边距合并的问题(其实是因为 ...
- 由外边距合并到BFC
置顶文章:<纯CSS打造银色MacBook Air(完整版)> 上一篇:<JavaScript实现Ajax小结> 作者主页:myvin 博主QQ:851399101(点击QQ和 ...
- 文本溢出、垂直外边距合并、BFC、hasLayout
今天学习文本溢出,又遇到了一些小问题,先上图: 关于文本溢出推荐:http://www.cnblogs.com/yzg1/p/5089534.html 从里面学习到单行文本和多行文本溢出, overf ...
随机推荐
- 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新
[原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...
- ASP.NET Aries 入门开发教程9:业务表单的开发
前言: 经过前面那么多篇的列表的介绍,终于到了大伙期待的表单开发了. 也是本系列的最后一篇文章了! 1:表单页面的权限设置与继承 对于表单页面,权限的设置有两种: 1:你可以选择添加菜单(设置为不显示 ...
- nodejs进阶(5)—接收请求参数
1. get请求参数接收 我们简单举一个需要接收参数的例子 如果有个查找功能,查找关键词需要从url里接收,http://localhost:8000/search?keyword=地球.通过前面的进 ...
- Python的单元测试(二)
title: Python的单元测试(二) date: 2015-03-04 19:08:20 categories: Python tags: [Python,单元测试] --- 在Python的单 ...
- [C#] C# 知识回顾 - 你真的懂异常(Exception)吗?
你真的懂异常(Exception)吗? 目录 异常介绍 异常的特点 怎样使用异常 处理异常的 try-catch-finally 捕获异常的 Catch 块 释放资源的 Finally 块 一.异常介 ...
- 【原创分享·微信支付】 C# MVC 微信支付教程系列之公众号支付
微信支付教程系列之公众号支付 今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付.现在,我们讲讲这个公众号支付.公众号支付的应用环境常见的用户通过公众号,然后再通 ...
- HotApp小程序服务范围资质查询器
微信小程序提交审核需要选择资质服务范围,如果服务范围不对,审核会不通过, 开发小程序之前,最好先查询所开发小程序的资质范围,否则无法通过微信审核. 小程序的资质范围查询地址,数据同步微信官方 ht ...
- 我的MYSQL学习心得(四) 数据类型
我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(五) 运 ...
- 开始mono开发
使用mono框架开发android程序,第一步当然是构建开发环境,严格意义上说是使用 mono for android开发android程序. 参考Mono for Android安装配置破解 mo ...
- mono for android 自定义titleBar Actionbar 顶部导航栏 修改 样式 学习
以前的我是没有做笔记的习惯的,学习了后觉得自己能记住,但是最近发现很多学的东西都忘记了,所有现在一有新的知识,就记下来吧. 最近又做一个mono for android 的项目 这次调整比较大,上次做 ...