1. BFC(Block formatting context)直译为"块级格式化上下文"。它是一个独立的渲染区域,(只有Block-level box参与,它规定了内部的Block-level Box如何布局,并且与这个区域外部毫不相干。)
2.BFC的布局规则有:
1.BFC就是在页面上的一个独立的隔离的容器,容器里面的子元素不会影响到外面的元素,外面的元素也不会影响到容器里面的子元素;
2.BFC内部的box会在垂直方向上一个接一个的放置;
3.margin折叠(Box垂直方向的距离由margin决定,属于同一个BFC的两个相邻Box的margin会发生折叠);
4.每个元素的margin box的左边,与包含块border box的左边相接触(对于从左往右的格式话,否则相反),即使存在浮动也是如此;
5.BFC的区域不会与float box发生重叠(浮动元素脱离文档流后面元素跟上去);
6.计算BFC的高度时,浮动元素也参与计算;
3.会生成BFC的元素有:
1.根元素
2.float不为none的元素
3.overflow不为visible的元素
4.position为absolute或fixed的元素
5.display为inline-block、inline-flex、flex、table-cell、table-caption的元素
4.BFC的作用有防止margin折叠、自适应两栏布局、清除内容浮动等等
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗