记录--为什么没有人能讲清楚 BFC?

这篇具有很好参考价值的文章主要介绍了记录--为什么没有人能讲清楚 BFC?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

记录--为什么没有人能讲清楚 BFC?

一、你看得懂权威的解释吗?

1. CSS 规范中对 BFC 的描述

CSS 规范(英文) | 中文翻译

浮动,绝对定位的元素,非块盒的块容器(例如inline-blocks,table-cells和table-captions),以及’overflow’不为’visible’的块盒(当该值已被传播到视口时除外(except when that value has been propagated to the viewport))会为其内容建立新的块格式化上下文

在一个块格式化上下文中,盒在垂直方向一个接一个地放置,从包含块的顶部开始。两个兄弟盒之间的垂直距离由'margin'属性决定。同一个块格式化上下文中的相邻块级盒之间的垂直外边距会合并

在一个块格式化上下文中,每个盒的左外边界(left outer edge)挨着包含块的左外边界(对于从右向左的格式化,右外边界挨着)。即使存在浮动(尽管一个盒的行框可能会因为浮动而收缩 译注:环绕浮动元素放置的行框比正常的行短一些),这也成立。除非该盒建立了一个新的块格式化上下文(这种情况下,该盒自身可能会因为浮动变窄)

2. MDN 对 BFC 的描述

MDN链接

区块格式化上下文(Block Formatting Context,BFC)是 Web 页面的可视 CSS 渲染的一部分,是块级盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。

下列方式会创建块格式化上下文:

  • 文档的根元素(<html>)。
  • 浮动元素(即 float 值不为 none 的元素)。
  • 绝对定位元素(position 值为 absolute 或 fixed 的元素)。
  • 行内块元素(display 值为 inline-block 的元素)。
  • 表格单元格(display 值为 table-cell,HTML 表格单元格默认值)。
  • 表格标题(display 值为 table-caption,HTML 表格标题默认值)。
  • 匿名表格单元格元素(display 值为 table(HTML 表格默认值)、table-row(表格行默认值)、table-row-group(表格体默认值)、table-header-group(表格头部默认值)、table-footer-group(表格尾部默认值)或 inline-table)。
  • overflow 值不为 visible 或 clip 的块级元素。
  • display 值为 flow-root 的元素。
  • contain 值为 layoutcontent 或 paint 的元素。
  • 弹性元素(display 值为 flex 或 inline-flex 元素的直接子元素),如果它们本身既不是弹性、网格也不是表格容器。
  • 网格元素(display 值为 grid 或 inline-grid 元素的直接子元素),如果它们本身既不是弹性、网格也不是表格容器。
  • 多列容器(column-count 或 column-width (en-US) 值不为 auto,且含有 column-count: 1 的元素)。
  • column-span 值为 all 的元素始终会创建一个新的格式化上下文,即使该元素没有包裹在一个多列容器中(规范变更、Chrome bug)

格式化上下文影响布局,通常,我们会为定位和清除浮动创建新的 BFC,而不是更改布局,因为它将:

  • 包含内部浮动。
  • 排除外部浮动。
  • 阻止外边距重叠。

看了以上最权威的定义,你能看懂吗?如果不可以的话,那我们来看看国内 CSS 界大佬 —— 张鑫旭 的描述吧。

3. 张鑫旭对 BFC 的描述

博客链接

BFC全称”Block Formatting Context”, 中文为“块级格式化上下文”。啪啦啪啦特性什么的,一言难尽,大家可以自行去查找,我这里不详述,免得乱了主次,总之,记住这么一句话:BFC元素特性表现原则就是,内部子元素再怎么翻江倒海,翻云覆雨都不会影响外部的元素。所以,避免margin穿透啊,清除浮动什么的也好理解了。

张鑫旭直接不详细讲解了,而是让大家自行查找。

所以,不管你在网上怎么搜索,不管你问谁,你都无法得到关于 BFC 的详细定义。

二、为什么没法解释 BFC 是什么?

每个人都知道涩情是什么,但是没有一个人能把涩情说清楚

正如:

  1. 我不知道什么是 BFC
  2. 但是你写出样式,我就知道这是不是 BFC

BFC 就是这样的东西 (堆叠上下文也是)

  1. 它没有定义
  2. 他只有特性/功能

三、所以,我们究竟该如何理解 BFC?

既然 BFC 的定义我们讲不清楚,那我们就不去研究它的定义了,我们知道如何去使用就可以了,所以我们应该从特性/功能去理解 BFC

先把 BFC 翻译过来:

  • Block Formatting Context
  • 块级格式化上下文

功能1: 爸爸管儿子

用 BFC 包住浮动元素。(注意!这不是清除浮动,.clearfix 才是清除浮动)

在特定的情况下,会导致父容器无法包裹住子容器,请看代码:

<style>
  .father{
    border: 1px solid red;
  }

  .son{
    height: 100px;
    background: blue;
    width: 400px;
    float: left; <- 注意这一行
  }
</style>

<div class="father">
  <div class="son"></div>
</div>

正常来讲,father 是会抱住裹住 son 的,但我在 son 加上 float: left; 之后,却包不住了,看下面效果截图:

记录--为什么没有人能讲清楚 BFC?

解决方法:

  • father 浮动起来,例如加上:float:left;
  • father 设置为绝对定位,例如加上:position: absolute
  • father 变为非块盒容器,例如加上:display: inline-blocks
  • 不让 fatheroverflow 的值为 visible,例如加上:overflow: auto
    (overflow 的默认值是 visible)
  • 使用绝招:在 father 上添加 display: flow-root;,这段代码只有一个功能,就是让当前元素变成一个 BFC,并且没有其他的副作用!

但是在 BFC 里的元素的垂直 margin 合并

功能2: 兄弟之间划清界限

float + div 做左右自适应布局

看代码:

<style>
  .big-bro{
    width: 100px;
    height: 200px;
    background:rgba(0,0,0,0.3);
    float: left;
    border: 2px solid blue;
  }

  .young-ber{
    height: 200px;
    background: yellow;
    border: 5px solid red;
  }
</style>

<div class="big-bro"></div>
<div class="young-ber"></div>

效果图:

哥哥把弟弟压到下面去了!

记录--为什么没有人能讲清楚 BFC?

解决方法:在弟弟元素加上:overflow: auto;

请看效果:

记录--为什么没有人能讲清楚 BFC?

总结

所以,不要尝试解释什么是 BFC,因为你一解释就错,我不明白面试官为什么经常要问 :)

本文转载于:

https://juejin.cn/post/7303392509664247835

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

 记录--为什么没有人能讲清楚 BFC?文章来源地址https://www.toymoban.com/news/detail-746895.html

到了这里,关于记录--为什么没有人能讲清楚 BFC?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 五分钟了解GPT 模型背后的原理是什么?为什么 GPT 模型能生成有意义的文本?为什么 GPT 模型不会做简单的数学题?为什么有人担心 GPT 模型可能会危害人类?

    五分钟了解GPT 模型背后的原理是什么?为什么 GPT 模型能生成有意义的文本?为什么 GPT 模型不会做简单的数学题?为什么有人担心 GPT 模型可能会危害人类?

    由于 GPT 模型的相关内容非常丰富,所以我计划对它进行更加深入的学习和研究,并把它应用到自己的工作、生活和学习中,用来提高工作效能,改善生活质量,提升学习效果。 按照第一性原理,在开始实战演练之前,我认为有必要先了解一下 GPT 模型背后的原理,这样才能

    2024年02月07日
    浏览(16)
  • 维护积极的react native,为什么会有人造谣react native不维护了,停止维护。

    维护积极的react native,为什么会有人造谣react native不维护了,停止维护。

            其实近几年我一直关注react -native,他一直更新频繁,0.60大重构,升级了js执行引擎Hermes,当前已经0.70.4版本了。性能越来越提高,但是总感觉到有人在刷百度,只要输入react-native后面就自动提示热搜“react-native 停止维护”,这误导很多人以为真的不维

    2024年02月11日
    浏览(11)
  • Elasticsearch 为什么能做到快速检索?秘密在这里!,Java全栈知识体系

    Elasticsearch 为什么能做到快速检索?秘密在这里!,Java全栈知识体系

    如果你了解 ES 应该知道,ES 可以说是对 Lucene 的一个封装,里面关于倒排索引的实现就是通过 lucene 这个 jar 包提供的 API 实现的,所以下面讲的关于倒排索引的内容实际上都是 lucene 里面的内容。 三、倒排索引 首先我们还不能忘了我们之前提的搜索需求,先看下建立倒排索引

    2024年04月12日
    浏览(10)
  • uniapp前端+python后端=微信小程序支付到底怎么开发???国内的资料为什么没一篇能讲清楚,简简单单的只需要3步就可以了-V2版本

    uniapp前端+python后端=微信小程序支付到底怎么开发???国内的资料为什么没一篇能讲清楚,简简单单的只需要3步就可以了-V2版本

    真的,在接到这个任务的时候,本以为很简单,不就是普通的浏览器复制粘贴,最不济找下gpt给生成一下,但是到实际开发就不同了,不是后端出问题就是前端,搜资料,上百度上google,基本每一个人讲的都不一样,不是这问题就是那问题,特别是微信官方,自己接口的逻辑

    2024年01月22日
    浏览(16)
  • 你用过猿如意吗?猿如意可以使用ChatGPT哦,这里详细介绍了猿如意的功能,为什么我建议你使用猿如意,来看看吧

    你用过猿如意吗?猿如意可以使用ChatGPT哦,这里详细介绍了猿如意的功能,为什么我建议你使用猿如意,来看看吧

    你是否还在为为每次安装IDE(集成开发工具)要去各种网站找教程而烦恼? 你是否还在为各种文本格式转换而头痛? 你是否在为斗图都不过兄弟们而卑微? 你是否在为互联网中庞大冗杂却低效的教程文档而崩溃? 你想不想有一个关于代码的模板库? 你想不想不用\\\"科技\\\"就使

    2023年04月13日
    浏览(12)
  • 记录--居中为什么要使用 transform?

    记录--居中为什么要使用 transform?

    居中是我们在前端布局中经常会遇到的问题,其中包括水平居中和垂直居中。居中的方法很多,比如说水平居中可以使用 text-align: center 或者 margin: 0 auto 等等来实现,垂直居中则需要使用一些其它的特殊的技巧。比如说常见的做法是使用 transform 来实现垂直居中, margin-top 或

    2024年02月05日
    浏览(11)
  • 记录--强制缓存这么暴力,为什么不使用协商缓存

    记录--强制缓存这么暴力,为什么不使用协商缓存

    前段时间在看面经的时候,发现很多份面经中都被问到了 强缓存 和 协商缓存 。因此我觉得有必要写一篇文章来好好聊聊这两者。 浏览器缓存是浏览器在本地磁盘对用户最近请求过的文档进行存储,当访问者再次访问同一页面时,浏览器就可以直接从本地磁盘加载文档,其中浏览

    2024年02月10日
    浏览(19)
  • 记录--为什么推荐用svg而不用icon?

    记录--为什么推荐用svg而不用icon?

    使用背景: 1.因为svg图标在任何设备下都可以高清显示,不会模糊。而icon会在显卡比较低的电脑上有显示模糊的情况 2.svg图标在页面render时 速度会比icon稍微快一点 3.实现小程序换肤功能 ;方案见:www.yuque.com/lufeilizhix… SVG基础可参考:www.yuque.com/lufeilizhix… inline svg是目前前

    2024年02月08日
    浏览(14)
  • 微信为什么使用 SQLite 保存聊天记录?

    微信为什么使用 SQLite 保存聊天记录?

      SQLite 是一个被大家低估的数据库,但有些人认为它是一个不适合生产环境使用的玩具数据库。事实上,SQLite 是一个非常可靠的数据库,它可以处理 TB 级的数据,但它没有网络层。接下来,本文将与大家共同探讨 SQLite 在过去一年中最新的 SQL 功能。   SQLite “只是”一个库

    2024年02月10日
    浏览(46)
  • 记录--post为什么会发送两次请求?

    记录--post为什么会发送两次请求?

    在前段时间的一次面试中,被问到了一个如标题这样的问题。要想好好地去回答这个问题,这里牵扯到的知识点也是比较多的。 那么接下来这篇文章我们就一点一点开始引出这个问题。 在浏览器中,内容是很开放的,任何资源都可以接入其中,如 JavaScript 文件、图片、音频

    2024年02月12日
    浏览(14)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包