经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTMLCSS » CSS » 查看文章
margin的两个有趣现象:margin合并和margin塌陷
来源:cnblogs  作者:乘风踏西行  时间:2018/10/15 9:03:37  对本文有异议

margin合并

当两个元素在垂直方向并列,分别设置margin值时会发生一个margin合并的现象

举个例子,有两个div,垂直并列,box1设置margin-bottom:20px,box2设置margin-top:50px,

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>test</title>
  6. <style type="text/css">
  7. *{
  8. margin0;
  9. padding: 0;
  10. }
  11. div{
  12. width: 50px;
  13. height: 50px;
  14. }
  15. #box1{
  16. margin-bottom: 20px;
  17. background: red;
  18. }
  19. #box2{
  20. margin-top: 50px;
  21. background: blue;
  22. }
  23. </style>
  24. </head>
  25. <body>
  26. <div id="box1"></div>
  27. <div id="box2"></div>
  28. </body>
  29. </html>

按照一般的思维,这两个div之间的距离就应该是70px,事实并非如此,两个div之间的距离只有50px,因为两个div的margin重叠,它会取最大值

               

 

一般来说margin合并不常见,因为只需设置一个div的margin来达到二者之间的距离就可以了

margin塌陷

margin塌陷很常见,存在于嵌套关系的盒子之间。

有两个div,box1包含box2,给box2一个margin-top:20px,让box2和box1之间产生20px的距离

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>test</title>
  6. <style type="text/css">
  7. *{
  8. margin0;
  9. padding: 0;
  10. }
  11. #box1{
  12. width: 100px;
  13. height: 100px;
  14. background: red;
  15. }
  16. #box2{
  17. width: 50px;
  18. height: 50px;
  19. margin-top: 20px;
  20. background: blue;
  21. }
  22. </style>
  23. </head>
  24. <body>
  25. <div id="box1">
  26. <div id="box2"></div>
  27. </div>
  28. </body>
  29. </html>

结果会发现box1和box2没产生距离,反而是box1带着box2离页面顶端20px

           

解决办法:

  1. 给父级盒子设置overflow:hidden
  2. 给父级盒子设置border
  3. 给父级盒子设置padding

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号