国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > CSS > 正文

詳解css外邊距折疊(margin collapsing)

2024-07-11 08:59:35
字體:
供稿:網(wǎng)友

前文

這是的一個經(jīng)典的老問題,因為之前剛好有讀者朋友問到,順便整理一下。

從一個簡單例子說起

先看一個簡單示例:

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

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

分類情況

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

  1. 相鄰元素
  2. 父元素和第一個子元素(或者最后一個子元素,等下記得回頭思考下這里為啥是第一個或者最后一個)
  3. 空的塊級元素

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

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


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

他們的圖像也分別如圖:

情況2: 子元素的外邊距會“轉(zhuǎn)移”到父元素的外面

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

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

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

  • 第一個例子中,兩個<p>標簽的垂直方向margin是直接接觸的;
  • 第二個例子中,由于父元素的padding,border都為0,所以margin和它的子元素也是直接接觸的。(這個例子畫出盒模型就很好理解)
  • 第三個例子中,空元素本身的上下邊距也是直接接觸的(padding,border也是0)

各種情況下折疊的結(jié)果

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

  • 如果兩個外邊距都是正值,折疊后的邊距取較大的一個
  • 如果兩個邊距一正一負,折疊后的邊距為邊距之和
  • 如果兩個邊距都為負數(shù),折疊后邊距為較小的邊距之和

如何防止外邊距折疊

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

  • 嵌套情況只要border padding 非0,或者有inline元素隔開,比如父元素里加一行文字也可以(可以直接在情況2嘗試)
  • 任何借助bfc形成阻隔的方式,如浮動,display:table等(BFC不熟悉的同學先查查,我后面補上)

小結(jié)

還得補充一下,前面討論的是基本情況,在基本情況下還可以進行組合,比如多個相鄰元素之間;多層后代元素嵌套等等,弄明白基本原理,其他情況只要寫寫小的demo驗證下就很好理解了。然后是慣例:如果內(nèi)容有錯誤的地方歡迎指出(覺得看著不理解不舒服想吐槽也完全沒問題);

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持武林網(wǎng)。

原文地址:https://segmentfault.com/a/1190000016842993

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 伊吾县| 凌云县| 凤阳县| 金坛市| 南陵县| 长海县| 来安县| 凤山县| 晋城| 新邵县| 乐东| 巴彦淖尔市| 丹棱县| 耒阳市| 滕州市| 邮箱| 商河县| 重庆市| 郑州市| 徐州市| 大安市| 越西县| 阳春市| 色达县| 平江县| 偏关县| 万宁市| 吉水县| 收藏| 昌乐县| 成都市| 普兰店市| 夏邑县| 阳朔县| 云林县| 岚皋县| 于都县| 西丰县| 怀化市| 海淀区| 平度市|