BFC
全称:Block Formatting Context
, 名为 "块级格式化上下文"。css
W3C
官方解释为:BFC
它决定了元素如何对其内容进行定位,以及与其它元素的关系和相互做用,当涉及到可视化布局时,Block Formatting Context
提供了一个环境,HTML
在这个环境中按照必定的规则进行布局。html
简单来讲就是,BFC
是一个彻底独立的空间(布局环境),让空间里的子元素不会影响到外面的布局。那么怎么使用BFC
呢,BFC
能够看作是一个CSS
元素属性前端
这里简单列举几个触发BFC
使用的CSS
属性git
BFC
就是一个块级元素,块级元素会在垂直方向一个接一个的排列BFC
就是页面中的一个隔离的独立容器,容器里的标签不会影响到外部标签BFC
的两个相邻的标签外边距会发生重叠BFC
的高度时,浮动元素也参与计算<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>高度塌陷</title>
<style> .box { margin: 100px; width: 100px; height: 100px; background: red; float: left; } .container { background: #000; } </style>
</head>
<body>
<div class="container">
<div class="box"></div>
<div class="box"></div>
</div>
</body>
</html>
复制代码
效果:github
能够看到上面效果给box
设置完float
结果脱离文档流,使container
高度没有被撑开,从而背景颜色没有颜色出来,解决此问题能够给container
触发BFC
,上面咱们所说到的触发BFC
属性均可以设置。npm
修改代码markdown
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>高度塌陷</title>
<style> .box { margin: 100px; width: 100px; height: 100px; background: red; float: left; } .container { background: #000; display: inline-block; } </style>
</head>
<body>
<div class="container">
<div class="box"></div>
<div class="box"></div>
</div>
</body>
</html>
复制代码
效果:数据结构
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style> .box { margin: 10px; width: 100px; height: 100px; background: #000; } </style>
</head>
<body>
<div class="container">
<div class="box"></div>
<div class="box"></div>
</div>
</body>
</html>
复制代码
效果:app
能够看到上面咱们为两个盒子的margin
外边距设置的是10px
,可结果显示两个盒子之间只有10px
的距离,这就致使了margin
塌陷问题,这时margin
边距的结果为最大值,而不是合,为了解决此问题可使用BFC
规则(为元素包裹一个盒子造成一个彻底独立的空间,作到里面元素不受外面布局影响),或者简单粗暴方法一个设置margin
,一个设置padding
。ide
修改代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Margin边距重叠</title>
<style> .box { margin: 10px; width: 100px; height: 100px; background: #000; } </style>
</head>
<body>
<div class="container">
<div class="box"></div>
<p><div class="box"></div></p>
</div>
</body>
</html>
复制代码
效果:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>两栏布局</title>
<style> div { width: 200px; height: 100px; border: 1px solid red; } </style>
</head>
<body>
<div style="float: left;">
两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局
</div>
<div style="width: 300px;">
我是蛙人,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭
</div>
</body>
</html>
复制代码
效果:
能够看到上面元素,第二个div
元素为300px
宽度,可是被第一个div
元素设置Float
脱离文档流给覆盖上去了,解决此方法咱们能够把第二个div
元素设置为一个BFC
。
修改代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>两栏布局</title>
<style> div { width: 200px; height: 100px; border: 1px solid red; } </style>
</head>
<body>
<div style="float: left;">
两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局两栏布局
</div>
<div style="width: 300px;display:flex;">
我是蛙人,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭,若有帮助请点个赞叭
</div>
</body>
</html>
复制代码
效果:
谢谢你读完本篇文章,但愿对你能有所帮助,若有问题欢迎各位指正。
我是蛙人(✿◡‿◡),若是以为写得能够的话,请点个赞吧❤。
感兴趣的小伙伴能够加入 [ 前端娱乐圈交流群 ] 欢迎你们一块儿来交流讨论
写做不易,「点赞」+「在看」+「转发」 谢谢支持❤
《聊聊什么是CommonJs和Es Module及它们的区别》
《【建议收藏】分享一些工做中经常使用的Git命令及特殊问题场景怎么解决》