margin的两个有趣现象:margin合并和margin塌陷
程序员文章站
2022-06-18 23:47:11
margin合并 当两个元素在垂直方向并列,分别设置margin值时会发生一个margin合并的现象 举个例子,有两个div,垂直并列,box1设置margin-bottom:20px,box2设置margin-top:50px, 按照一般的思维,这两个div之间的距离就应该是70px,事实并非如此 ......
margin合并
当两个元素在垂直方向并列,分别设置margin值时会发生一个margin合并的现象
举个例子,有两个div,垂直并列,box1设置margin-bottom:20px,box2设置margin-top:50px,
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>test</title> <style type="text/css"> *{ margin:0; padding: 0; } div{ width: 50px; height: 50px; } #box1{ margin-bottom: 20px; background: red; } #box2{ margin-top: 50px; background: blue; } </style> </head> <body> <div id="box1"></div> <div id="box2"></div> </body> </html>
按照一般的思维,这两个div之间的距离就应该是70px,事实并非如此,两个div之间的距离只有50px,因为两个div的margin重叠,它会取最大值
一般来说margin合并不常见,因为只需设置一个div的margin来达到二者之间的距离就可以了
margin塌陷
margin塌陷很常见,存在于嵌套关系的盒子之间。
有两个div,box1包含box2,给box2一个margin-top:20px,让box2和box1之间产生20px的距离
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>test</title> <style type="text/css"> *{ margin:0; padding: 0; } #box1{ width: 100px; height: 100px; background: red; } #box2{ width: 50px; height: 50px; margin-top: 20px; background: blue; } </style> </head> <body> <div id="box1"> <div id="box2"></div> </div> </body> </html>
结果会发现box1和box2没产生距离,反而是box1带着box2离页面顶端20px
解决办法:
- 给父级盒子设置overflow:hidden
- 给父级盒子设置border
- 给父级盒子设置padding
上一篇: 获取浏览器滚动距离
下一篇: 初学leaflet(一)引入地图资源