CSS之BFC及其应用
BFC是Block Formatting Context的缩写,直译过来就是“块级格式化上下文”。先不管它到底是什么,看一个例子:
.parent{
border: 1px solid blue;
}
.children{
width: 100px;
height: 100px;
background: red;
float: left;
margin: 10px;
}
<div class="parent">
<div class="children"></div>
<div class="children"></div>
</div>
结果:
想必大家都了解,子元素float时父容器是不会被撑开高度的。一般的解决方法是给父容器加上 .clearFix类,
.clearfix:after{
content:".";
display:block;
height:0;
clear:both;
visibility:hidden
}
清除浮动后,父容器能自动获得正确的高度了:
现在通过BFC,可以用更简单的方法解决这个问题了,只需要在父容器的样式里加上一句 overflow: hidden :
.parent{
border: 1px solid blue;
overflow: hidden;
}
原理:块级元素使用 overflow: hidden 的时候会创建一个 BFC ,而计算BFC的高度时,浮动元素也会参与计算。
BFC还有另外一个非常重要的特性,那就是垂直方向的外边距重叠,还是之前那两个div,样式改为:
.children{
width: 100px;
height: 100px;
background: red;
margin: 50px 10px;
overflow: hidden;
}
我们为两个div设置了上下50px的外边距,按理来说两个div的距离应该是100px;然而事与愿违,
上边div的margin-bottom与下边div的margin-top重叠了。
当然,BFC的特性不止这些,创建BFC的方法也不只有overflow: hidden。
BFC元素的特性
参考w3-CSS2规范,9.4.1节,总结如下:
1 内部的Box会在垂直方向从上到下排列。
2 内部的Box会在水平方向从左到右排列(对于从右到左的格式化则相反)。即使存在浮动也是如此。
3 Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生折叠
4 BFC的区域不会与float box叠加。这条后边会解释
5 BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素,反之亦然。
6 计算BFC的高度时,浮动元素也参与计算。
哪些元素会创建BFC?
- 根元素
- float元素
- 绝对定位元素(position属性为absolute或fixed)
- 不是块级框的元素(display属性为inline-block, table-cell, table-caption等)
- overflow属性不为visible的元素
BFC的应用场景
1 闭合浮动 即前边父容器获取高度问题,不再介绍了 注意这里不叫清除浮动,因为BFC元素可以包含浮动元素,并且浮动元素也参与计算高度。
2 防止垂直 margin 重叠
前边提到的垂直外边距折叠问题,可以通过给子元素外层包裹一个BFC块,像这样:
<div class="parent">
<div class="children"></div>
<div class="BFC">
<div class="children"></div>
</div>
</div>
这样之前的两个children块便不属于同一个BFC了。但是一般不建议滥用BFC来解决此类问题,推荐使用同向的margin-top,margin-bottom来解决。
3 多列布局
前边BFC特性第4条提到了,BFC的区域不会与float box叠加,这句话是什么意思呢,看一个例子:
.food{
width: 100px;
height: 100px;
float: left;
}
<div class="container">
<img class="food" src="food.png">
<p class="BFC">商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍商品介绍
</p>
</div>
当我们展示一张图片和介绍性文字的时候,一般会给图片加上float属性,但是有时候这种文字环绕的方式不是我们要的效果,怎么将图片和文字变成两列式布局呢?很简单,给文字的容器p元素创建一个BFC。
.BFC{
overflow: hidden;
}
使用BFC,很简单方便的就将效果实现了。
图片和文字过于紧凑显然不够美观,我们给图片和文字设置20px的间距。如果直接给文字块设置左边距,需要将图片的宽度计算在内,即120px,这种方式显然不好。这种情况我们只需给浮动的元素设置一个20px的右边距即可。
.food{
width: 100px;
height: 100px;
float: left;
margin-right: 20px;
}
总结
- BFC是指块级格式化上下文,它是一个独立的渲染区域,内部的元素布局方式与外部无关;
- 主要特点是相邻元素间垂直方向的外边距会被折叠,以及内部的浮动元素会参与计算高度;
- 主要用途是闭合浮动使父容器自动获得高度,以及实现多列布局。
个人理解仅供参考,如有错误欢迎指正。
CSS之BFC及其应用的更多相关文章
- CSS之BFC、IFC、FFC and GFC
CSS之BFC.IFC.FFC and GFC 什么是FC? BFC(Block Formatting Contexts) BFC的布局规则: 如何生成BFC: IFC(Inline Formatti ...
- 理解CSS中BFC
BFC(Block Formatting Context) 是Web页面中盒模型布局的CSS渲染模式.它的定位体系 属于 常规文档流 .摘自 W3C : 浮动,绝对定位元素, inline-block ...
- CSS的BFC和hasLayout及其应用场景
前端精选文摘:BFC 神奇背后的原理 一.BFC是什么? 先介绍 Box.Formatting Context的概念. Box: CSS布局的基本单位 Box 是 CSS 布局的对象和基本单位, 直观 ...
- css 之 BFC
1,定义 BFC为块级格式化上下文,也就是一块区域内的封闭空间,里面元素无论怎么样,都不会影响外部元素. 2,触发条件 html 根元素 display的值为 inline-block.table-c ...
- 理解css的BFC
BFC是CSS中一个看不见的盒子,(先理解CSS的盒子模型).它的页面渲染方式与普通流的盒子模型不同,它决定了其子元素将如何定位(所用属于BFC的box 都默认左对齐),以及和其他元素的关系和相互作用 ...
- CSS之BFC详解
What:了解该知识点的概念,本质以及有关牵扯到的相关知识概念 BFC这个东西说常见的话你可能不觉得,但是你肯定会常用,也许你在用的时候也没想到BFC这东西.网上也有很多写这些东西的文章,但是自己写一 ...
- 浏览器的差距、ie6 ie7 ie8、符号、html css、BFC、
1.浏览器的差距 浏览器默认的字体是16px,谷歌的最小字体是12px,其他是10px 2.ie6.ie7.ie8. hack:就是针对不同的浏览器去不同的html,css样式,从而让各个浏览器能达到 ...
- 前端精选文摘:css之BFC 神奇背后的原理(转载)
一.BFC是什么? 在解释 BFC 是什么之前,需要先介绍 Box.Formatting Context的概念. Box: CSS布局的基本单位 Box 是 CSS 布局的对象和基本单位, 直观点来说 ...
- 【HTML/CSS】BFC
块格式化上下文(Block formatting contexts) BFC是什么? 是Web页面中盒模型布局的CSS渲染模式.它的定位体系属于常规文档流. 至少满足条件之一: float 的值不为 ...
- 总结下对我对于CSS中BFC的认知
首先第一个,什么是BFC? BFC的全称叫Block Formatting Context (块级格式化上下文)BFC是css中隐含属性,开启BFC后元素会变成一个独立的布局环. 简单来说,它 ...
随机推荐
- oracle删除字段中的空格、回车及指定字符
create or replace procedure PROC_test is --Description:删除字段中的指定字符(回车chr(13).换行chr(10)) --By LiChao - ...
- 怎样获得PRINCE2证书?报名PRINCE2有什么条件?
参加培训:想要获得PRINCE2资格证书,参加培训是非常必要的,正规的培训机构有获得组织认证考试的权力.光环国际全年开设prince2课程班,全国各个地区均可以选择培训及考试 选择培训机构:只有经AP ...
- STM32学习笔记(二)——串口控制LED
开发板芯片:STM32F407ZGT6 PA9-USART1_TX,PA10-USART1_RX; PF9-LED0,PF10-LED1; 一.串口1配置过程(不使用串口中断): 1.使能时钟,包括G ...
- linux sed命令就是这么简单
概述 sed命令是一个面向字符流的非交互式编辑器,也就是说sed不允许用户与它进行交互操作.sed是按行来处理文本内容的.在shell中,使用sed来批量修改文本内容是非常方便的. sed命令的选项 ...
- 《阿里巴巴Java开发手册(正式版》读记
前几天,阿里巴巴发布了<阿里巴巴Java开发手册(正式版>,第一时间下载阅读了一番. 不同于一般大厂内部的代码规范,阿里巴巴的这本Java开发手册,可谓包罗万象,几乎日常Java开发中方方 ...
- HDU 5556 最大独立集
这题主要有了中间的一些连通块的限制,不太好直接用二分图最大独立集做.考虑到图比较小,可以作补图求最大团来求解. #include <iostream> #include <vecto ...
- 使用CSharp编写Google Protobuf插件
什么是 Google Protocol Buffer? Google Protocol Buffer( 简称 Protobuf) 是 Google 公司内部的混合语言数据标准,目前已经正在使用的有超过 ...
- java线程的实现
一共有两种方法Thread类和Runnable接口,相对来讲,更趋向于用Runnable因为一个类可以实现多个接口,但是只能继承一个类,所以相对来说倾向用Runnable 第一种方法:用Thread其 ...
- WPF 杂谈——入门介绍
对于WPF的技术笔者是又爱又恨.现在WPF的市场并不是很锦气.如果以WPF来吃饭的话,只怕会饿死在街头.同时现在向面WEB开发更是如火冲天.所以如果是新生的话,最好不要以WPF为主.做为选择性来学习一 ...
- Jsoup抓取、解析网页和poi存取excel综合案例——采集网站的联系人信息
需求:采集网站中每一页的联系人信息 一.创建maven工程,添加jsoup和poi的依赖包 <!-- https://mvnrepository.com/artifact/org.apache. ...