溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在css中折疊外邊距

發(fā)布時間:2021-06-07 16:03:23 來源:億速云 閱讀:156 作者:Leah 欄目:web開發(fā)

怎么在css中折疊外邊距?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

先看一個簡單示例:

<style>
    .slide1 div {
      margin:10px 0;
    }
  </style>
 <div class="slide1">
    <h4>第1種外邊距折疊:兄弟元素</h4>
    <p>文本上下間距10px</p>
    <p>文本上下間距10px</p>
  </div>

怎么在css中折疊外邊距

怎么在css中折疊外邊距

看這個例子中的兩個p標簽,根據樣式定義:第一個pmargin-bottom和第二個pmargin-top 都是10px,那實際距離應該等于20px才對,但是用瀏覽器查看一下可以發(fā)現,最終的邊距是10px。 這個例子就是外邊距折疊:塊級元素的上外邊距和下外邊距有時會合并(或折疊)為一個外邊距。

分類情況

外邊距折疊有3種基本情況:

  1. 相鄰元素

  2. 父元素和第一個子元素(或者最后一個子元素,等下記得回頭思考下這里為啥是第一個或者最后一個)

  3. 空的塊級元素

先不急著記憶,首先,前文的例子中就是第一種情況--相鄰的兩個元素之間發(fā)生的外邊距折疊。

第二種和第三種情況如下:

怎么在css中折疊外邊距


怎么在css中折疊外邊距

<style>
    .father {
      background-color: green;

    }
    .child {
      margin-top: 50px;
      background-color: red;
      height: 300px;
    }
    
      .slide3 {
      margin: 10px 0;
    }
  </style>
  <h4>第2種外邊距折疊:父元素和首個子元素</h4>
  <div class="slide2 father">
    <!-- 父元素是綠色 -->
    <div class="slide2 child">
      <!-- 子元素是紅色 -->
    </div>
  </div>
  <h4>第3種外邊距折疊:空的塊級元素</h4>
  <div class="slide3"></div>

他們的圖像也分別如圖:

情況2: 子元素的外邊距會“轉移”到父元素的外面

情況3:該元素的上下外邊距會折疊

好了,到這里我們不妨來看看這幾種情況的共同點(建議畫一下他們的盒模型,我懶就不畫了-_-),可以發(fā)現發(fā)生外邊距折疊的共同原因:margin之間直接接觸,沒有阻隔。

如何理解直接接觸?很簡單:

  • 第一個例子中,兩個<p>標簽的垂直方向margin是直接接觸的;

  • 第二個例子中,由于父元素的padding,border都為0,所以margin和它的子元素也是直接接觸的。(這個例子畫出盒模型就很好理解)

  • 第三個例子中,空元素本身的上下邊距也是直接接觸的(padding,border也是0)

各種情況下折疊的結果

折疊后的邊距如何計算,這個可以簡單驗證下:

  • 如果兩個外邊距都是正值,折疊后的邊距取較大的一個

  • 如果兩個邊距一正一負,折疊后的邊距為邊距之和

  • 如果兩個邊距都為負數,折疊后邊距為較小的邊距之和

如何防止外邊距折疊

前文說到,發(fā)生外邊距折疊的原因是,外邊距直接接觸,因此防止折疊的方式就是,阻隔這個直接接觸,組合的方法包括:

  • 嵌套情況只要border padding 非0,或者有inline元素隔開,比如父元素里加一行文字也可以(可以直接在情況2嘗試)

  • 任何借助bfc形成阻隔的方式,如浮動,display:table等(BFC不熟悉的同學先查查,我后面補上)

看完上述內容,你們掌握怎么在css中折疊外邊距的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

css
AI