从0开始学习BFC
为什么需要BFC?
<style>
.red {
background: red;
}
.blue {
background: #1890ff;
}
.green {
background: green;
}
p {
margin: 20px 0;
}
</style>
<body>
<p class="red">1</p>
<p class="blue">2</p>
<p class="green">3</p>
</body>
最常见的问题就是margin折叠。div1和div2之间的间距是20px,而不是预想的40px。该问题创建BFC就可以解决,因为BFC不会影响其他元素的布局。
BFC是什么?
BFC:Box Formatting Context,直译为块级格式化上下文。在CSS2.1规范中定义的一个关于css渲染定位的概念。BFC是一个独立的渲染区域,规定该区域内部的box 如何布局,并且与这个区域的外部毫不想干。
在CSS2.1规范中,还定义了Inline formatting context(IFC)。CSS3中添加了G(grid)FC和F(flex)FC
如何创建BFC?
详情请看CSS2.1规范 https://www.w3.org/TR/CSS2/visuren.html#block-formatting
这里写个总结,满足以下条件之一的元素便会生成BFC。
- 根元素
- 浮动元素: float的值不为none
- 绝对定位元素: position的值为absolute或fixed
- 行内块元素: display: inline-block
- 表格单元格: display的值为table-cell,table-caption
- overflow的值不为visible的元素
- 弹性盒子 display:flex或inline-flex
BFC的规则是什么?
- 内部的box会在垂直方向上一个接一个放置。
- 垂直方向的距离有margin决定,属于同一个BFC的两个相邻box的margin会发生重叠,与方向无关。
- 每个元素的margin box的左边与包含块border box的左边相接触。存在浮动也是如此。
- BFC的区域不会与float的元素区域重叠。
- 计算BFC的高度时,浮动子元素也参与计算。
- BFC就是页面上的一个隔离的独立容器,容器里的子元素不会影响到外面元素,反之亦然
回归问题
文章开头的问题?
三个div同属于一个BFC(此处是body)中,所以根据规则第二点,margin会发生重叠。
解决方案:
p标签外在添加一个容器,并设置属性overflow:hidden。这样就产生了3个BFC,3个p在3个不同的BFC中,就不会产生margin重叠的问题。
<style>
.red {
background: red;
}
.blue {
background: #1890ff;
}
.green {
background: green;
display: flex;
}
p {
margin: 20px;
}
.wrap {
overflow: hidden;
}
</style>
<body>
<div class="wrap">
<p class="red">1</p>
</div>
<div class="wrap">
<p class="blue">1</p>
</div>
<div class="wrap">
<p class="green">1</p>
</div>
</body>
除了margin重叠还有其他的作用吗?
- 清除浮动
<style>
.par {
border: 5px solid #fcc;
width: 300px;
/* display: inline-block; */
}
.child {
border: 5px solid #189ff0;
width:100px;
height: 100px;
float: left;
}
</style>
<body>
<div class="par">
<div class="child">1</div>
<div class="child">2</div>
</div>
</body>
参考规则第五点,计算BFC的高度时,浮动子元素也参与计算。形成BFC后,par就会把浮动子元素的高度也计算进去。
- 不和浮动元素重叠
<style>
body {
width: 100%;
position: relative;
}
.aside {
width: 100px;
height: 150px;
float: left;
background: #f66;
}
.main {
height: 200px;
background: #fcc;
/* overflow: hidden; */
}
</style>
<body>
<div class="aside"></div>
<div class="main">
</div>
</body>
形成自适应两列布局。应用了BFC规则第四点。
从0开始学习BFC的更多相关文章
- IdentityServer4 ASP.NET Core的OpenID Connect OAuth 2.0框架学习保护API
IdentityServer4 ASP.NET Core的OpenID Connect OAuth 2.0框架学习之保护API. 使用IdentityServer4 来实现使用客户端凭据保护ASP.N ...
- 20145208 《Java程序设计》第0周学习总结
20145208 <Java程序设计>第0周学习总结 阅读心得 读了老师推荐的几个文章,虽然第四个文章"为什么一定要自学"报告资源不存在而无法阅读,其他的三篇文章都言之 ...
- Json.Net6.0入门学习试水篇
原文:Json.Net6.0入门学习试水篇 前言 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.简单地说,JSON 可以将 JavaScript 对象中 ...
- Bootstrap3.0入门学习系列
Bootstrap3.0入门学习系列规划[持续更新] 前言 首先在此多谢博友们在前几篇博文当中给与的支持和鼓励,以及在回复中提出的问题.意见和看法. 在此先声明一下,之前在下小菜所有的随笔文章中, ...
- 自己从0开始学习Unity的笔记 I (C#字符串转换为数字)
我基本上从0开始学习编程,运算符基本上跳过,因为知道了 “=”这个符号相当于赋值,然后“==”才是等于,其他和普通运算符号差不都,也就跳过了. 最基础的赋值那种,我看了下代码,似乎没什么难度,估计新手 ...
- 从0开始学习 GITHUB 系列之「向GITHUB 提交代码」【转】
本文转载自:http://stormzhang.com/github/2016/06/04/learn-github-from-zero4/ 版权声明:本文为 stormzhang 原创文章,可以随意 ...
- 从0开始学习 GITHUB 系列之「GIT 速成」【转】
本文转载自:http://stormzhang.com/github/2016/05/30/learn-github-from-zero3/ 版权声明:本文为 stormzhang 原创文章,可以随意 ...
- 从0开始学习 GITHUB 系列之「加入 GITHUB」【转】
本文转载自:http://stormzhang.com/github/2016/05/26/learn-github-from-zero2/ 版权声明:本文为 stormzhang 原创文章,可以随意 ...
- 20145328 《Java程序设计》第0周学习总结
20145328 <Java程序设计>第0周学习总结 阅读心得 从总体上来说,这几篇文章都是围绕着软件工程专业的一些现象来进行描述的,但深入了解之后就可以发现,无论是软件工程专业还是我们现 ...
随机推荐
- 【技术累积】【点】【java】【22】UUID
基础概念&使用 UUID是Universally Unique Identifier的缩写,它是在一定的范围内(从特定的名字空间到全球)唯一的机器生成的标识符. 说白了就是个唯一键,只不过到处 ...
- LDAP个人理解
在新的公司办公,所有的后台系统或文档系统都公用一个LDAP账号. 接触到这个新名词,就查了一下,谈谈个人理解: LDAP是个协议, 简单地说,可以把LDAP服务理解为一套存放你账户密码的数据库系统.市 ...
- 洛谷——P2574 XOR的艺术
P2574 XOR的艺术 很久之前就想挑战一下这道题了,线段树下传标记的入门题,跟区间加法下传标记类似. #include<bits/stdc++.h> #define N 1000005 ...
- 刽子手游戏(Hangman Judge, UVa 489)
刽子手游戏其实是一款猜单词游戏,游戏规则是这样的:计算机想一个单词让你猜,你每次可以猜一个字母.如果单词里有那个字母,所有该字母会显示出来:如果没有那个字母,则计算机会在一幅“刽子手”画上填一笔.这幅 ...
- Java 内存模型与线程
when ? why ? how ? what ? 计算机的运行速度和它的存储和通信子系统速度的差距太大,大量的时间都花费在磁盘I/O .网络通信或者数据库访问上.如何把处理器的运算能力"压 ...
- linux中的umask命令
转载:http://blog.51cto.com/1123697506/882064 一 权限掩码umask umask是chmod配套的,总共为4位(gid/uid,属主,组权,其它用户的权限),不 ...
- 详解Cookie、LocalStorage、SessionStorage
不管是笔试还是面试相信大家都会经常遇到问Cookie.LocalStorage.SessionStorage 这三个不同的,什么不说先上一波图先: 针对他们大小之分应用场景也有不同: 因为考虑到每个 ...
- 网页title上面添加图片
1.效果:
- JVM内存管理和垃圾回收机制介绍
http://backend.blog.163.com/blog/static/20229412620128233285220/ 内存管理和垃圾回收机制是JVM最核心的两个组成部分,对其内部实 ...
- MYSQL 源码
http://www.cnblogs.com/wingsless/tag/MySQL/