css中常見margin塌陷問題之解決辦法

塌陷問題


 

當兩個盒子在垂直方向上設置margin值時,會出現一個有趣的塌陷現象。

①垂直並列

    首先設置兩個DIV,併爲其制定寬高
  1. 複製代碼
     1 /*HTML部分*/
     2 <body>
     3     <div class="box1">box1</div>
     4     <div class="box2">box2</div>
     5 </body>
     6 /*CSS部分*/
     7 <style> 
     8     *{
     9          margin: 0; 
    10          padding: 0; 
    11     }
    12      .box1{ 
    13          width: 200px; 
    14          height: 200px; 
    15          background: yellowgreen;
    16      } 
    17     .box2{ 
    18          width: 200px; 
    19          height: 200px; background: gray; 
    20     }
    21 </style>    
    複製代碼

     

          
     
      對box1咱們爲其設置margin-bottom:50px;
     對box2咱們爲其設置margin-top: 40px;
  1. 複製代碼
     1 <style>
     2 *{
     3     margin:0;
     4     padding:0;
     5 }
     6 .box1{
     7     width:200px;
     8     height:200px;
     9     background: yellowgreen;
    10     margin-bottom: 50px;
    11 }
    12 .box2{
    13     width:200px;
    14     height:200px;
    15     background: gray;
    16     margin-top: 40px;
    17 }
    18 </style>
    複製代碼
      咱們確定會很理所固然的認定這兩個盒子之間的距離爲90px,事實上並不是如此.
     以下圖所示:
          
     兩盒子之間的距離僅是50px,也就是說兩盒子之間的margin出現了重疊部分,故而咱們能夠得出:垂直之間塌陷的原則是以兩盒子最大的外邊距爲準。
 

②嵌套關係(父級元素塌陷)

  1. 複製代碼
     1 /*CSS部分*/
     2 <style>
     3 .box1{
     4     width:400px;
     5     height:400px;
     6     background: pink;
     7 }
     8 .box2{
     9     width:200px;
    10     height:200px;
    11     background: lightblue;
    12 }
    13 </style>
    14 /*HTML部分*/
    15 <body>
    16     <divclass="box1">
    17     <divclass="box2"></div>
    18 </div>
    19 </body>
    複製代碼
     如圖示
 
         
     當爲子盒子添加margin-top:10px;時會發生以下狀況:
          
    子盒子和父盒子之間並沒出現指望的10px間隙而是父盒子與子盒子一塊兒與頁面頂端產生了10px間隙(即父級盒子往下塌陷了10px)。
 
解決方法:
(1)爲父盒子設置border,爲外層添加border後父子盒子就不是真正意義上的貼合  (能夠設置成透明:border:1px solid transparent)。
(2)爲父盒子添加overflow:hidden;
(3)爲父盒子設定padding值;
(4)爲父盒子添加position:fixed;
(5)爲父盒子添加 display:table;
(6)利用僞元素給子元素的前面添加一個空元素
.son:before{ content:"";
             overflow:hidden; }
相關文章
相關標籤/搜索