理解 CSS 布局和块级格式上下文

简介: BFC 的概念始于 CSS2,是个蛮古老的 CSS 话题了,网上也到处能搜到 BFC 的介绍,但是都不够简洁。本文系翻译自 Rachel Andrew 女士的博文 Understanding CSS Layout And The Block Formatting Context,内容足够简洁明了。

本文的目的是介绍一些概念来帮你增强 CSS 码力。如标题所示这篇文章主要是讲块级格式上下文BFCBlock Formatting Context。你可能没听过这个术语但只要你曾经使用 过CSS 布局你就能明白它。理解 BFC 是什么、它如何工作、如何创建一个 BFC 是非常有用的这些能帮你更好的理解 CSS 布局。

这篇文章里我会通过几个你会很熟悉的的示例解释 BFC。我还会告诉你一个新的 display 值当你理解了 BFC 后可能会很需要这个值。

目录

什么是 BFC

一个简单的浮动的示例就能明白 BFC 的行为在下面的示例中我们创建一个 box 元素该元素包裹一段文字和一个浮动的图片。 如果文字内容多的话文字将环绕着整个浮动图片box 的边框会把他们整个包裹起来。


文字环绕着浮动元素

但如果把一些文字删除就没有足够的文字去环绕图片浮动元素了同时由于浮动元素脱离文档流box 元素的边框高度就会随文字的减少而降低。


没有足够的文字box 元素边框的高度就会低于浮动元素的高度

之所以会发生这种情况是由于当我们浮动一个元素后box 元素仍然保持原来的宽度是文字所占的空间缩短了以给浮动元素腾出位置这就是为什么背景和边框能够看起来包裹住了浮动元素。

我们通常会使用两种不同的方式来解决这个问题一种是使用 clear hack就是在 文字和图片的下方插入一个 div 并将它的 CSS clear 属性设值为 both。另外一种方法是使用 overflow 属性 把它设值成非默认值 visible的值。


使用 overflow: auto 后 box 就能包裹浮动元素了

overflow 之所以能够有效是因为当它的是是非 visible 时会创建一个 BFC而 BFC 的功能之一就是包裹浮动元素

BFC 是布局中的迷你布局

你可以把 BFC 当做你页面中的一块小布局当一个元素被创建成 BFC 后它其中的所有元素都会被它包裹。正如我们所见当 box 元素变成 BFC 后它其中的浮动元素就再也没能突破它的底部。除此之外BFC 还有一些有用的功能。

BFC 可以阻挡外边距叠加margins collapsing

理解外边距叠加是另外一个被低估的 CSS 技巧。在接下来的示例里我创建了一个背景灰色的 div这个 div 含有两个段落div 元素的 margin-bottom 为 40px同时每个段落都有 20px 的 margin-top 与 margin-bottom。

由于 p 元素的边缘与 outer 元素的边缘之间没有任何东西所以 outer 与 p 的 margin 会叠加p 会与 outer 的顶部与底部齐平p 对外的 margin 似乎与 outer 的 margin 合并了使我们无法在段落的上下看到 outer 的灰色背景。


由于 margin collapse外边距叠加我们看到 outer 内部上下没有灰色背景

如果我们把 outer 元素变成 BFC它就可以包裹住 p 以及 p 的 margin外边距不会发生叠加outer 元素内部就会出现由 p 元素的 margin 顶出来的上下灰色背景。


建立 BFC 后外边距不再叠加

一旦 BFC 建立它就会阻止它内部的元素逃离突破它。

一个 BFC 会停止去环绕浮动元素

你可能很熟悉 BFC 的这个特性我们在有浮动元素的列类型布局中常用到。如果一个元素创建了 BFC它就不会去环绕或者说包装任何浮动元素。看下面这个示例

class 名为 float 的元素将会浮动在布局的左侧class 名为 text 的 div 元素将会在它后面并环绕它。


文字环绕着浮动元素

我们可以通过给 text 元素建立 BFC 来阻挡这种环绕行为。


text 元素建立 BFC 后就不再环绕浮动元素了

该方法也是我们创建浮动布局的基本方式。还需注意的是浮动一个元素时也会给该元素创建 BFC也就是说此时 .float 与 .text 都是 BFC这也是无论右侧高度低于还是高于左侧两者都不会互相围绕的原因。

创建一个 BFC 的常用方式

除了使用 overflow 外 一些其他的 CSS 属性也可以创建 BFC比如上面我们所见浮动一个元素也可以为该元素创建 BFC浮动元素会包裹它内部的所有元素。还有以下几种方式可以创建 BFC

使用 position: absolute 或者 position fixed

使用 display: inline-blockdisplay: table-cell 或者 display: table-caption其中 table-cell 和 table-caption是表格相关 HTML 元素的对应默认 CSS 值所以当你创建表格每个表格单元都会自动创建 BFC。

另外当使用 multi-column layout 多列布局时使用 colum-span: all 也可以创建 BFC。Flex弹性 和 Grid网格 布局中的元素也会自动创建类似 BFC 的机制只是它们被称为 Flex Formatting Context弹性格式上下文和 Grid Formatting Context(网格格式上下文)。这反映了它们所参与的布局类型。一个 Block Formatting Context块级格式上下文表明他内部的元素参与了块级布局一个 弹性格式上下文意味着它内部的元素参与了弹性布局。在实践中这几种布局的结果是相似的浮动元素会被包裹、外边距不会叠加。

创建 BFC 的新方式

使用 overflow 或其他的方法创建 BFC 时会有两个问题。第一个是这些方法本身是有自身的设计目的的所以在使用它们创建 BFC 时会可能产生副作用。例如使用 overflow 创建 BFC 后在某些情况下你可能会看到出现一个滚动条或者元素内容被削减。这是由于 overflow 属性是设计被用来让你告诉浏览器如何定义元素的溢出状态的。浏览器执行了它最基本的定义。

另一个问题是即使在没有出现副作用的情况下使用 overflow 也可能会使另一个开发人员感到困惑。他们可能会各种猜想这里为啥要把 overflow 的值设为 auto 或 scroll原开发人员做这个意义何在原开发人员是想让这里出现滚动条吗

最安全的做法应该是创建一个 BFC 时不会有任何副作用它内部的元素都安安全全的呆在这个小布局里这种方法不会引起任何意想不到的问题也可以让开发者意图清晰。CSS 工作组也十分认同这种想法所以他们定制了一个新的属性值display: flow-root

你可以使用 display: flow-root 安全的创建 BFC 来解决本文中提到的各种问题包括包裹浮动元素、阻止外边距叠加、阻止环绕浮动元素。


caniuse 上 display: flow-root 各浏览器支持情况

浏览器对该属性值的支持目前还是有限的如果你觉得这个属性值很方便请投票去让 Edge 也支持它。不过无论如何你现在应该已经理解了什么是 BFC以及如何使用 overflow 或其他方法来包裹浮动以及知道了 BFC 可以阻止元素去环绕浮动元素如果你想使用弹性或网格布局可以在一些不支持他们的浏览器中使用 BFC 的这些特性做降级处理。

理解浏览器如何布置网页是非常基础的。 虽然有时看起来无关紧要但是这些小知识可以加快创建和调试 CSS 布局所需的时间。


本文转载自前端记录http://www.ferecord.com/understanding-css-layout-block-formatting-context.html

目录
相关文章
|
1天前
|
前端开发 容器
前端 css 经典:grid 栅格布局
前端 css 经典:grid 栅格布局
9 1
|
2天前
|
前端开发 容器
CSS 弹性布局,大厂意外流出
CSS 弹性布局,大厂意外流出
|
3天前
|
前端开发 UED
【专栏:HTML与CSS实战项目篇】创建一个具有复杂布局的电商详情页
【4月更文挑战第30天】构建复杂布局的电商详情页涉及页面结构规划、样式设计和交互效果实现。首先规划顶部导航栏、商品图片展示区、商品信息区、用户评价区和相关商品推荐区。在样式设计上,注重色彩搭配、字体选择、布局与间距及图片处理。交互效果包括图片放大、添加到购物车按钮、滚动监听和评论互动,以提升用户体验。实际开发中需考虑跨设备兼容性和用户体验优化。
|
3天前
|
编解码 缓存 前端开发
【专栏:HTML与CSS移动端开发篇】移动端网页布局与适配
【4月更文挑战第30天】本文探讨了如何使用HTML和CSS优化移动端网页布局与适配,强调响应式设计、灵活布局和媒体查询的重要性。针对移动设备的屏幕尺寸、操作方式、网络速度和性能差异,提出了断点选择、触摸优化、图像和性能优化等最佳实践。测试和调试、框架工具的应用也是关键步骤,以确保在多设备上提供优秀用户体验。开发者需持续学习新趋势和工具,以适应移动端发展。
|
3天前
|
前端开发 UED 容器
【专栏:CSS进阶篇】CSS Grid布局:构建复杂的二维布局
【4月更文挑战第30天】CSS Grid布局是二维布局系统,适用于复杂页面结构,如页眉、主体和侧边栏。通过定义网格线和单元格,能轻松创建行和列。基本语法包括设置容器为grid容器,定义`grid-template-rows`和`grid-template-columns`。高级特性包括命名网格线、网格区域、网格间隙、重复网格线和自动填充。在实际应用中,CSS Grid能有效提升开发效率和用户体验,尤其在响应式设计和复杂布局场景下。
|
3天前
|
前端开发 开发者 容器
【专栏:CSS进阶篇】CSS Flexbox布局:实现灵活的响应式设计
【4月更文挑战第30天】CSS Flexbox是现代网页设计中创建响应式布局的关键工具,它提供了一种一维布局模型,使元素能灵活适应各种屏幕尺寸。通过设置容器的`display`属性为`flex`,开发者可以利用主轴和交叉轴调整元素排列和对齐方式。核心概念包括弹性项、伸缩性、空间分配和对齐。通过实例,如导航栏、卡片布局、图片画廊和响应式表单,展示了Flexbox在实现响应式设计中的应用。尽管需要注意浏览器兼容性,但掌握Flexbox能帮助开发者构建出功能强大且适应性强的界面。
|
3天前
|
前端开发 开发者 容器
【专栏:CSS基础篇】CSS定位与布局:从静态到浮动、定位
【4月更文挑战第30天】本文介绍了CSS定位与布局的基础,包括静态、相对、绝对、固定定位以及浮动。静态定位遵循HTML顺序,相对定位可在正常位置基础上偏移,不占用额外空间。绝对定位基于最近已定位祖先元素定位,脱离文档流。固定定位相对于浏览器窗口定位,无视页面滚动。浮动用于文字环绕图片等,可能导致父元素高度塌陷。Flexbox布局提供更灵活的元素排列和对齐方式,适配各种复杂布局需求。理解并掌握这些布局技术能提升网页设计的灵活性和响应性。
|
3天前
|
移动开发 HTML5
HTML5/CSS3粒子效果进度条代码
HTML5/CSS3进度条应用。这款进度条插件在播放进度过程中出现粒子效果,就像一些小颗粒从进度条上散落下来
19 0
HTML5/CSS3粒子效果进度条代码
|
3天前
|
移动开发 前端开发 JavaScript
:掌握移动端开发:HTML5 与 CSS3 的高效实践
:掌握移动端开发:HTML5 与 CSS3 的高效实践 “【5月更文挑战第6天】”
27 1
|
3天前
|
缓存 移动开发 前端开发
【专栏:HTML与CSS前端技术趋势篇】HTML与CSS在PWA(Progressive Web Apps)中的应用
【4月更文挑战第30天】PWA(Progressive Web Apps)结合现代Web技术,提供接近原生应用的体验。HTML在PWA中构建页面结构和内容,响应式设计、语义化标签、Manifest文件和离线页面的创建都离不开HTML。CSS则用于定制主题样式、实现动画效果、响应式布局和管理字体图标。两者协同工作,保证PWA在不同设备和网络环境下的快速、可靠和一致性体验。随着前端技术进步,HTML与CSS在PWA中的应用将更广泛。