|
8 | 8 | ## 高度塌陷
|
9 | 9 | 我们知道,如果一个块级元素没有设置固定的高度,那么它的高度会被高度最大的子元素撑起,如下:
|
10 | 10 | 在容器中有 box1 和 box2 两个元素,容器的高度被 box1 撑起
|
11 |
| -``` |
| 11 | + |
12 | 12 | <div style="background-color: aqua;display:flex">
|
13 | 13 | <div style="height:100px;width:100px;background-color: red;line-height:100px;text-align:center;color:white">box1</div>
|
14 | 14 | <div style="height:50px;width:150px;background-color: blue;line-height:50px;text-align:center;color:white">box2</div>
|
15 | 15 | </div>
|
16 |
| -``` |
| 16 | + |
17 | 17 | 如果给 box1 添加浮动、定位等,使其脱离了正常的文档流,即产生了高度塌陷
|
18 |
| -``` |
| 18 | + |
19 | 19 | <div style="background-color: aqua;">
|
20 | 20 | <div style="height:100px;width:100px;background-color: red;line-height:100px;text-align:center;color:white;float: left;">box1</div>
|
21 | 21 | <div style="height:50px;width:150px;background-color: blue;line-height:50px;text-align:center;color:white">box2</div>
|
22 | 22 | </div><br>
|
23 |
| -``` |
| 23 | + |
24 | 24 | ## 外边距塌陷
|
25 | 25 | 外边距塌陷也称为外边距合并,是指两个在正常流中相邻(兄弟或父子关系)的块级元素的外边距,组合在一起变成单个外边距,不过只有上下外边距才会有塌陷,左右外边距不会出现这种问题。
|
26 | 26 | ### 兄弟元素
|
27 |
| -``` |
28 | 27 | <div style="margin-bottom: 5px; background-color: rgb(255, 147, 147)">
|
29 | 28 | 一寸光阴一寸金
|
30 | 29 | </div>
|
31 | 30 | <div style="margin-top: 30px; background-color: rgb(159, 159, 255)">
|
32 | 31 | 寸金难买寸光阴
|
33 | 32 | </div>
|
34 |
| -``` |
| 33 | + |
35 | 34 | ```
|
36 | 35 | <div style="margin-bottom: 5px; background-color: rgb(255, 147, 147)">
|
37 | 36 | 一寸光阴一寸金
|
|
42 | 41 | ```
|
43 | 42 | 可以看到在有相邻 `margin-bottom` 和 `margin-top` 时,他们只会保留边距大的一个,而不是将其累加
|
44 | 43 | ### 父子元素
|
45 |
| -``` |
46 | 44 | <div style="background-color: rgb(224,224,224);height:300px;display:flow-root">
|
47 | 45 | <div style="background-color: rgb(122,122,222);width:200px;height:200px;">
|
48 | 46 | <div style="background-color: rgb(122,22,122);width:100px;height:100px;margin-top: 20px;"></div>
|
49 | 47 | </div>
|
50 | 48 | </div>
|
51 |
| -``` |
52 | 49 | 这种现象我们应该经常会遇到,无论是给父元素还是子元素边距,他们都会有边距。
|
53 | 50 | 以上情形都可以通过 BFC 解决,那么什么是 BFC ?
|
54 | 51 |
|
|
0 commit comments