分享好友 最新动态首页 最新动态分类 切换频道
BFC
2024-12-26 22:47

 最初这篇文章打算回答寒冬大神的第一问,谈谈CSS布局。本来呢我以为布局主要涉及float跟display相关属性,以及他们的包含框、静态位置等等。后来看了大神的一片面试文章,嗯?这里怎么还有个BFC,这是神马东东。待我搜索一下,萨萨萨,不看不知道,越看越糊涂,这到底是个神马东东。。。经过一个周时间的查阅资料和自我思考,在此总结一下我对BFC的认识,愿与各位道友分享,欢迎拍砖!

BFC

 

  对CSS有了解的道友们肯定都知道盒式模型这个概念,对一个元素设置CSS,首先需要知道这个元素是block还是inline类型。而BFC就是用来格式化块级盒子,同样管理inline类型的盒子还有IFC,以及其他的FC。那首先我们就来看一下FC的概念。

   Formatting Context:指页面中的一个渲染区域,并且拥有一套渲染规则,他决定了其子元素如何定位,以及与其他元素的相互关系和作用。

  BFC:块级格式化上下文,它是指一个独立的块级渲染区域,只有Block-level BOX参与,该区域拥有一套渲染规则来约束块级盒子的布局,且与区域外部无关。

 

  BFC的生成

 

  既然上文提到BFC是一块渲染区域,那这块渲染区域到底在哪,它又是有多大,这些由生成BFC的元素决定,CSS2.1中规定满足下列CSS声明之一的元素便会生成BFC。

  • 根元素
  • float的值不为none
  • overflow的值不为visible
  • display的值为inline-block、table-cell、table-caption
  • position的值为absolute或fixed

  看到有道友文章中把display:table也认为可以生成BFC,其实这里的主要原因在于Table会默认生成一个匿名的table-cell,正是这个匿名的table-ccell生成了BFC

 

  BFC的约束规则

 浏览器对于BFC这块区域的约束规则如下:

  • 生成BFC元素的子元素会一个接一个的放置。垂直方向上他们的起点是一个包含块的顶部,两个相邻子元素之间的垂直距离取决于元素的margin特性。在BFC中相邻的块级元素外边距会折叠。
  • 生成BFC元素的子元素中,每一个子元素做外边距与包含块的左边界相接触,(对于从右到左的格式化,右外边距接触右边界),即使浮动元素也是如此(尽管子元素的内容区域会由于浮动而压缩),除非这个子元素也创建了一个新的BFC(如它自身也是一个浮动元素)。

  有道友对它做了分解,我们直接拿来:

  1. 内部的Box会在垂直方向上一个接一个的放置
  2. 垂直方向上的距离由margin决定。(完整的说法是:属于同一个BFC的两个相邻Box的margin会发生重叠,与方向无关。)
  3. 每个元素的左外边距与包含块的左边界相接触(从左向右),即使浮动元素也是如此。(这说明BFC中子元素不会超出他的包含块,而position为absolute的元素可以超出他的包含块边界)
  4. BFC的区域不会与float的元素区域重叠
  5. 计算BFC的高度时,浮动子元素也参与计算
  6. BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面元素,反之亦然

  看到以上的几条约束,让我想起学习css时的几条规则

  • Block元素会扩展到与父元素同宽,所以block元素会垂直排列
  • 垂直方向上的两个相邻DIV的margin会重叠,而水平方向不会(此规则并不完全正确)
  • 浮动元素会尽量接近往左上方(或右上方)
  • 为父元素设置overflow:hidden或浮动父元素,则会包含浮动元素
  • ......

  哈哈,一股恍然大悟的感觉有木有,原来这些规则的背后都有更深层的概念,冥冥之中自有定数。。。

  

  BFC在布局中的应用

  上面说了那么多,那BFC究竟有何用处,毕竟再好的东西也要为我所用才行。

  防止margin重叠:

  同一个BFC中的两个相邻Box才会发生重叠与方向无关,不过由于上文提到的第一条限制,我们甚少看到水平方向的margin重叠。这在IE中是个例外,IE可以设置write-mode。下面这个demo来自寒冬大神的博客。

  

  可以看到水平方向的margin发生了重叠。  

  要阻止margin重叠,只要将两个元素别放在一个BFC中,即使用上文提到的方式让相邻元素其中一个生成BFC。阻止两个相邻元素的margin重叠看起来没有什么意义,主要用于嵌套元素。

  此时div与ul之间的垂直距离,取div、ul、li三者之间的最大外边距。

  要阻止嵌套元素的重叠,只需让ul生成BFC即可(将上例中的注释去掉),这样div、ul、li之间便不会发生重叠现象。而li位于同一BFC内所以仍然存在重叠现象。

  需要注意的是:

  • 如果将为ul使用overflow:hidden的方式,ul生成BFC不应该再发生重叠现象可是我在chrome、firefox、ie上的测试结果都有发生重叠现象。这个问题,我没找到答案,还请道友们给解答一下
  • 如果为ul设置了border或padding,那元素的margin便会被包含在父元素的盒式模型内,不会与外部div重叠。《CSS权威指南》中提到块级正常流元素的高度设置为auto,而且只有块级子元素,其默认高度将是从最高块级子元素的外边框边界到最低块级子元素外边框边界之间的距离。如果块级元素右上内边距或下内边距,或者有上边框或下边框,其高度是从其最高子元素的上外边距边界到其最低子元素的下外边距边界之间的距离。

  浮动相关问题:

  使得父元素包含子元素,常见的方式是为父元素设置overflow:hidden或浮动父元素。根本原因在于创建BFC的元素,子浮动元素也会参与其高度计算,即不会产生高度塌陷问题。实际上只要让父元素生成BFC即可,并不只有这两种方式。

  将上例中first中任意一项注释去掉都可以得到包围浮动的效果,其中overflow:hidden方式,与正常流最接近。

  关于清除浮动更详尽的方式,请大家参考这篇文章此处,dolphinX道友的博客简洁明了。

  多栏布局的一种方式

  上文提到的一条规则:与浮动元素相邻的已生成BFC的元素不能与浮动元素相互覆盖。利用该特性可以作为多栏布局的一种实现方式。

  这种布局的特点在于左右两栏宽度固定,中间栏可以根据浏览器宽度自适应。

  IE中也有与BFC类似的概念成为hasLayout,我平时工作最低也是使用IE8,并没有涉及到这部分所以还请道友们查询其他资料。

  总结

  在我第一次接触到BFC时经常有一个疑问,BFC的结构是什么样的,像DOM一样的树状结构,还是一个BFC集合。其实我们不需要关心BFC的具体结构,这要看浏览器的具体实现采用什么样的数据结构。对于BFC我们只需要知道使用一定的CSS声明可以生成BFC,浏览器对生成的BFC有一系列的渲染规则,利用这些渲染规则可以达到一定的布局效果,为了达到特定的布局效果我们让元素生成BFC。

  对于CSS新手来说不建议涉猎BFC,还是应该去看看相应的CSS布局规则,像《CSS设计指南》、《CSS权威指南》这两本都很不错,达到一定积累再来看BFC,说不定会有一种豁然开朗的感觉。BFC中几乎涉及到CSS布局的所有重要属性,这也是BFC的难点和我们需要掌握BFC的意义所在。

  文章中的部分内容可能与道友看到的其他博客有所出入,毕竟每个人的工作经验、所遇问题跟测试方法不一样,差异在所难免,探讨技术的乐趣在于不断的总结积累与自我推翻,只要大方向正确细节问题可以慢慢探索。

 

   参考文章

  http://www.cnblogs.com/winter-cn/archive/2012/11/16/2772562.html

  http://f2e-js.com/?p=2599

  http://www.cnblogs.com/dolphinX/p/3508869.html

  http://wenku.baidu.com/link?url=yRqbHnEVEL58mfPg1KDneWqX5AjcL34U70ANznTaWU6DUcTx6yaEcKBbDjPxyP3GVoNN7-GdTSPbEmty6RmCTJ3qY6FzPqSB7TvwbmFayYO

  http://reference.sitepoint.com/css/blockformatting

  http://www.yuiblog.com/blog/2010/05/19/css-101-block-formatting-contexts/

  http://www.cnblogs.com/winter-cn/archive/2013/05/11/3072929.html

最新文章
途胜是否能扛起北京现代紧凑型suv大旗?工薪族都养得起
从线条轮廓来看,融入了很多帅气的设计元素。汽车外观造型延续家族化设计理念,前脸设计显得激进,两侧犀利的大灯设计,内部灯组错落有致,点亮时炯炯有神。侧面的腰线依旧是现代独到的整体外观,妖娆的身段更是展现的淋漓尽致!轮圈造型有
二战风云2怎么提升战绩 二战风云战绩怎么才能升得快
掌握正确的游戏十分重要。在《二战风云》中,想要提升战绩,必须要合理分配资源,有针对性地提升自己的部队实力。随机地提升部队实力是无法帮助你获得更高的战绩的,反而可能让你陷入资源短缺的窘境。玩家需要分析战场环境,制定合适的策略
连云港燃气灶售后电话24小时人工电话/快速联系客服 - 生活 - 百科知识-蓝心网
连云港燃气灶售后服务热线-服务电话400-658-8618连云港燃气灶是一家专业从事连云港燃气灶生产和销售的公司。作为一家以用户体验为核心的企业,连云港燃气灶致力于为客户提供优质的售后服务。无论是安装、使用还是维修,我们都秉承着高效、
网页关键词优化工具
SEO的专业性远超你的想象!我们要做的是协助搜索引擎而不是欺骗它!它涉及到的不止是网站结构、内容质量、用户体验、外部链接这几个方面;还有算法的更替、蜘蛛的引导、快照的更新、参与排序的权重等。一、让用户搜到你的网站是做SEO优化的
豆包跑火,哪个细分行业最受益,哪个股票领涨
来源:雪球App,作者: 仁者爱人普度众生,(https://xueqiu.com/1320842253/316538088)抖音豆包是一款由字节跳动公司开发的AI智能助手应用,基于云雀大模型开发,集成了先进的人工智能技术,能够回答用户提出的各种问题,如生活常识、科
麒麟seo的优化术语(麒麟seo的优化术语是什么)
大家好,今天小编关注到一个比较有意思的话题,就是关于麒麟seo的优化术语的问题,于是小编就整理了1个相关介绍麒麟seo的优化术语的解答,让我们一起看看吧。圣王麒麟链接怎么刷?方法如下:首先就是需要将这个圣王麒麟升到满级,然后进化
美媒:《猎人克莱文》口碑差,“蜘蛛侠宇宙”或遭重创
来源:环球时报 由亚伦·泰勒-约翰逊、罗素·克劳主演的《猎人克莱文》,讲述被父亲抛弃的少年谢尔盖,在遭遇野生雄狮袭击后身体意外变异,成为拥有超常力量的猎人克莱文,从此开始复仇之路。该片早在3年前就开始制作,原定于2023年1月上映
wordpress默认主题模板文件认知
wordpress默认主题模板文件认知与公共模板调用index.php                         首页默认主题模板 category.php                    分类列表页默认主题模板 page.php                         单页
pos机还安全吗
POS机的安全性分析随着科技的发展,POS机(Point of Sale)已成为现代商业交易不可或缺的一部分,随之而来的安全性问题也引起了广泛关注,本文将从五个方面对POS机的安全性进行详细阐述,以帮助商家和消费者更好地了解并评估POS机的安全性
谷歌商店play商店2023
《谷歌商店play商店》作为全球最大的应用商店之一,为安卓系统用户提供了丰富的应用、游戏、音乐、电影和杂志等资源。本文将带您深入了解Google Play商店的定义、历史背景、功能特点以及使用方法,让您更好地利用这个庞大的数字世界。Googl
相关文章
推荐文章
发表评论
0评