创建demo.html,内容如下
<style>
#root {
border: 2px solid black;
}
#test1 {
height: 100px;
width: 100px;
background-color: red;
margin: 50px;
}
#test2 {
height: 100px;
width: 100px;
background-color: blue;
margin: 50px;
}
</style>
<div id="root">
<div>
<div id="test1"></div>
</div>
<div>
<div id="test2"></div>
</div>
</div>
open demo.html,看到如图
image.png
test1和test2的margin重叠了,其实是bfc导致的
根元素(<html>)
浮动元素(元素的 float 不是 none)
绝对定位元素(元素的 position 为 absolute 或 fixed)
行内块元素(元素的 display 为 inline-block)
表格单元格(元素的 display 为 table-cell,HTML表格单元格默认为该值)
表格标题(元素的 display 为 table-caption,HTML表格标题默认为该值)
匿名表格单元格元素(元素的 display 为 table、table-row、 table-row-group、table-header-group、table-footer-group(分别是HTML table、row、tbody、thead、tfoot 的默认属性)或 inline-table)
overflow 值不为 visible 的块元素
display 值为 flow-root 的元素
contain 值为 layout、content 或 paint 的元素
弹性元素(display 为 flex 或 inline-flex 元素的直接子元素)
网格元素(display 为 grid 或 inline-grid 元素的直接子元素)
多列容器(元素的 column-count 或 column-width 不为 auto,包括 column-count 为 1)
column-span 为 all 的元素始终会创建一个新的BFC,即使该元素没有包裹在一个多列容器中(标准变更,Chrome bug)
解决办法就是,添加overflow:hidden
<style>
#root {
border: 2px solid black;
}
#test1 {
height: 100px;
width: 100px;
background-color: red;
margin: 50px;
}
#test2 {
height: 100px;
width: 100px;
background-color: blue;
margin: 50px;
}
</style>
<div id="root">
<div>
<div id="test1"></div>
</div>
<div style="overflow:hidden">
<div id="test2"></div>
</div>
</div>
最终如图
image.png
网友评论