摘要:當兩個及以上外邊距折疊,合并后的外邊距寬度是發生折疊的外邊距中的最大寬度。如果該元素的外邊距同其父元素的上外邊距折疊,則該盒的上邊框邊緣同其父元盒的上邊框邊緣相同。
2017-07-20: 關于外邊距折疊, 推薦問題: https://segmentfault.com/q/10...
8 盒模型 Box ModelURL: http://www.w3.org/TR/CSS2/box...
Translator : HaoyCn
Date: 15th of Aug, 2015
譯者注:本譯文僅擇精要部分翻譯了規范,主要描述了盒模型結構,以及重點分析外邊距折疊。個人水平有限,歡迎指正!
CSS盒模型所描述的矩形盒由文檔樹內的元素生成,根據視覺格式化模型布局。
8.1 盒尺寸 Box Dimensions每個盒都有一個內容區域 Content (如,文本,圖片等)以及可選的圍繞在周圍的內邊距、邊框和外邊距區域;每個區域的大小由本文后述的屬性指定。下圖展示了這些區域的關聯以及用于描述外邊距、邊框和內邊距的各部分的術語。
外邊距、邊框和內邊距可以被分解到上、右、下、左各部分(如,在上圖中, LM 表示左外邊距, RP 表示右內邊距, TB 表示上邊框等)。
四種區域(內容、內邊距、邊框、外邊距)的邊界被稱作一個“邊緣 Edge ”,因此每個盒有四種邊緣:
內容邊緣 Content Edge 或內邊緣 Inner Edge
內容邊緣圍繞著由盒的寬和高所指定的矩形,該矩形通常由元素的已渲染內容 Rendered Content 所決定。四個內容邊緣規定了盒的內容盒 Content Box 。
內邊距邊緣
內邊距邊緣圍繞著盒的內邊距。如果內邊距寬度為0,則內邊距邊緣即是內容邊緣。四個內邊距邊緣規定了盒的內邊距盒 Padding Box 。
邊框邊緣
邊框邊緣圍繞著盒的邊框。如果邊框寬度為0,則邊框邊緣即是內邊距邊緣。四個邊框邊緣規定了盒的邊框盒 Border Box 。
外邊距邊緣或外邊緣
外邊距邊緣圍繞著盒的外邊距。如果外邊距寬度為0,則外邊距邊緣即邊框邊緣。四個外邊距邊緣規定了盒的外邊距盒 Margin Box 。
每個邊緣都可以被分解成上、右、下、左邊緣。
盒內容區域的尺寸——即內容寬度 Content Width 和內容高度 Content Width ——由這些因素所決定:生成盒的元素是否設置了 width 和 height 屬性;盒是否包含了文本或其他盒;盒是否為表格;等等。盒的寬度和高度將在視覺格式化模型詳述一章中討論。
盒的內容、內邊距以及邊框區域的背景樣式由生成盒的元素的 background 屬性所規定。外邊距的背景始終為透明。
8.2 外邊距、內邊距和邊框的例子下例展示了外邊距、內邊距和邊框如何交互。HTML文檔:
Examples of margins, padding, and borders
該文檔結果為文檔樹中(省略其他關系)一個 ul 元素及其兩個 li 子元素。
下面的第一圖展示了例子的結果。第二圖展示了 ul 元素及其 li 子元素的外邊距、內邊距和邊框之間的關系。(圖片不成比例)
注意:
每個 li 盒的內容寬度是從上到下計算的;所有 li 盒的包含塊由 ul 元素創建。
每個 li 盒的外邊距盒高度由其內容高度加上上下內邊距、邊框、外邊距所決定。需要留意的是 li 盒間的垂直外邊距發生了折疊。
li 盒的右內邊距寬度被設為零( padding 屬性)。效果如第二圖所示。
li 盒的外邊距是透明的——外邊距總為透明——所以 ul 的內邊距和內容區域的背景顏色(黃)穿透外邊距顯示了出來。
第二個 li 元素指定了虛線邊框( border-style 屬性)。
8.3 外邊距各屬性外邊距的各屬性規定了盒的外邊距區域的寬度。 margin 設置所有四個方向的外邊距,而其他外邊距屬性則只設置各自方向寬度。這些屬性應用于所有元素,但垂直外邊距在非替代行內元素上無效。
8.3.1 外邊距折疊譯者注:此處以及下文的各屬性介紹均略,可查CSS手冊
在CSS中,兩個及以上的(不一定是同胞)盒的相鄰外邊距可能合并為一個多帶帶的外邊距。以這種方式的合并的外邊距被稱為折疊 Collapse ,合并后的外邊距被稱為折疊外邊距 Collapsed Margin 。
相鄰垂直外邊距發生折疊,除了:
根元素的盒的外邊距不折疊
如果一個有空隙的元素的上下外邊距相鄰,其外邊距將同其后同胞的相鄰外邊距折疊,但不同父塊的下外邊距折疊。
水平外邊距不重疊。
兩個外邊距為相鄰關系,當且僅當:
是同屬一個塊格式化上下文的文檔流內塊級盒
沒有行盒、空隙、內邊距和邊框分隔它們(注意某些零高度行盒會因此而被忽略(見9.4.2章))
盒邊緣垂直相鄰,也就是說,滿足以下形式之一:
盒上外邊距及其第一個文檔流內子盒的上外邊距
盒下外邊距及下一個文檔流內的同胞盒的上外邊距
如果父盒的高度計算值為 auto ,其最后一個文檔流內子盒的下外邊距及父盒的下外邊距
如果一個盒不建立新的塊格式化上下文、 min-height 計算值為零、 height 計算值為零或 auto 、沒有在文檔流內的子盒,其上下外邊距
如果一個折疊外邊距與另一外邊距的任何一邊相鄰,則視二者相鄰。
注意:不是同胞或祖先關系的元素也可以產生相鄰外邊距。
注意:上述規則表明了:
浮動盒的外邊距不同其他任何盒折疊(甚至浮動及其文檔流內的子元素也不折疊)
創建了新的塊格式化上下文的元素(如浮動、 overflow 不為 visible 的元素)的外邊距不同其在文檔流內的子元素外邊距折疊
絕對定位盒的外邊距不同其他任何盒折疊(甚至不同其文檔流內的子元素折疊)
行內塊盒的外邊距不同其他任何盒折疊(甚至不同其文檔流內的子元素折疊)
文檔流內塊級元素的下外邊距始終同其下一個文檔流內的塊級同胞的上外邊距折疊,除非該對同胞之間有空隙。
文檔流內塊元素如果沒有上邊框和上內邊距,其第一個文檔流內塊級子元素沒有空隙,二者的上外邊距折疊。
文檔流內 height 為 auto 、 min-height 為零、沒有下內邊距和下邊框的塊盒,如果其最后一個文檔流內塊級子盒的下外邊距沒有同一個有空隙的上外邊距折疊,二者下外邊距折疊。
如果某盒的 min-height 屬性為零、沒有上下邊框和上下內邊距、其 height 為0或 auto 、沒有包含行盒、其所有的文檔流內子元素外邊距(如果有)折疊,則折疊其外邊距。
當兩個及以上外邊距折疊,合并后的外邊距寬度是發生折疊的外邊距中的最大寬度。如果發生折疊的外邊距中有負數,則為最大正數相鄰外邊距減去最小負數相鄰外邊距的絕對值。如果不存在正數外邊距,則為零減去最小負數相鄰外邊距的絕對值。
如果一個盒的上下外邊距相鄰,則外邊距可能穿過盒而折疊 Collapse Through It 。這種情況下,元素的定位取決于它同其他外邊距折疊的元素的關系。
如果該元素的外邊距同其父元素的上外邊距折疊,則該盒的上邊框邊緣同其父元盒的上邊框邊緣相同。
否則,要么該元素的父元素的外邊距不折疊,要么只有父元素的下外邊距折疊。上邊框邊緣位置是假定該元素下邊框非零時的位置。
需要注意的是,被折疊穿過的元素的定位對與之外邊距折疊的其他元素的定位無影響;其上邊框邊緣的定位僅用于布局其后代元素。
8.6 雙向上下文 Bidirectional Context 中行內元素的盒模型對每個行盒而言,用戶代理必須按視覺順序(而非邏輯順序)渲染其生成的行內盒的外邊距、邊框和內邊距。
當元素 direction 屬性值為 ltr ,元素呈現的第一個行盒的最左生成盒擁有左外邊距、左邊框和左內邊距,而元素呈現的最后一個行盒的最右生成盒擁有右內邊距、右邊框和右外邊距。
當元素 direction 屬性值為 rtl ,元素呈現的第一個行盒的最右生成盒擁有右外邊距、右邊框和右內邊距,而元素呈現的最后一個行盒的最左生成盒擁有左內邊距、左邊框和左外邊距。
譯者之思譯者讀畢此文,細心揣摩,將經驗和疑問總結如下:
一、兩種盒模型本章節描述了W3C的標準盒模型,同時還存在IE6在怪異模式 Quicks Mode 的另一種盒模型。此處簡述二者的區別如下——
W3C標準下:盒總寬/高度 = width/height + padding + border + margin
怪異模式下:盒總寬/高度 = width/height + margin = 內容寬/高度 + padding + border + margin
CSS3中, box-sizing 默認為 content-box ,即采用W3C標準盒模型,若取值 border-box 則采用怪異模式盒模型。
二、不透明的外邊距CSS規范道:
盒的內容、內邊距以及邊框區域的背景樣式由生成盒的元素的 background 屬性所規定。外邊距的背景始終為透明。
但在根元素 html 上設置了外邊距,并規定了背景,該背景仍鋪滿全屏。
如下CSS:
html { margin: 50px; background: #000; }
body 同此理。譯者暫不知其因。歡迎讀者指教。
三、有空隙的元素外邊距折疊中,很多地方敘述了“有空隙的元素”,這是什么意思呢?其意義即是說,該元素清除了浮動。
在翻譯視覺格式化模型一章中,W3C給出了清除浮動以及計算空隙寬度的的案例,譯者建議讀者認真閱讀該部分,尤其關注:當空隙為負值時取消外邊距折疊的情形。
點此閱讀:http://segmentfault.com/a/119...。
如果讀者已經掌握清除浮動和空隙的知識,那就讓我們來看一個有空隙的情景。
如果一個有空隙的元素的上下外邊距相鄰,其外邊距將同其后同胞的相鄰外邊距折疊,但不同父塊的下外邊距折疊。
以下代碼中, B 是浮動塊,為清除其浮動, C 引入了空隙。
共同CSS:
html,body{padding:0;margin:0;} /*橫線,直觀對比折疊情況*/ .line{height:50px;background:red;} .mt{margin-top:50px;} .mb{margin-bottom:50px;} #B{float:left;width:1px;height:1px;} #C{clear:both;}
其外邊距將同其后同胞的相鄰外邊距折疊:
HTML:
渲染結果是, C 和 D 的外邊距折疊。
不同父塊的下外邊距折疊
HTML:
渲染結果是, C 的外邊距不同其父元素 A 的外邊距折疊。
四、避免盒自身垂直外邊距折疊如果一個盒不建立新的塊格式化上下文、 min-height 計算值為零、 height 計算值為零或 auto 、沒有在文檔流內的子盒,其上下外邊距
由此可以得出幾種避免盒自身上下外邊距折疊的辦法,簡單列舉如下:
建立新塊格式化上下文,如 overflow: hidden
設置 min-height
設置固定高 height
添加文檔流內(即非浮動、非絕對定位)子盒
需要注意最后一種辦法,子盒要么有邊框或內邊距,要么有內容,否則父盒的自身垂直外邊距同樣會折疊。而如果子盒只有垂直外邊距,該垂直外邊距將同父盒的垂直外邊距折疊,而不會阻止父盒自身垂直邊距折疊。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/111117.html
摘要:盒的類型會影響其在視覺格式化模型中的表現。浮動元素絕對定位元素根元素都被稱為脫離文檔流其他元素被稱為文檔流內。 視覺格式化模型 Visual Formatting Model URL:http://www.w3.org/TR/CSS2/visuren.html Translator: HaoyCn Date: 14th of Aug, 2015 本文并未全部翻譯,譯者在原文基礎上...
摘要:行盒的寬度由其包含塊給予,但可能因浮動而縮小。絕對定位不可替換元素的使用值約束為包含塊寬度如果和均為首先將以及值為的設為。 2015/10/08: 原10.8標題 行盒高度計算改為10.8 行高計算。英文原文為line height。由于翻譯時候看到那段結論是行盒的高度,腦抽就把原本翻譯對的標題改了下,剛回顧一番深覺不妥,故改回來。 原文:http://www.w3.org/TR/CS...
摘要:但該盒不建立新的層疊上下文,除非是根元素。以上是基于的層疊上下文介紹。同級情況下,按照二者在源代碼中的順序,居后的又重新占領高地了。現在我們看以下源代碼這個時候,以視口為包含塊進行定位和大小計算,將會鋪滿整個屏幕。 前言:關于層疊上下文,筆者還沒有去閱讀更詳細的 W3C 規范來了解更本質的原理(表打我,等我校招拿到 offer 了我就讀好伐 T_T)。一直聽說 CSS3 里的層疊上下文...
摘要:中各種布局的背后,實質上是各種的組合。相反,一些塊容器盒,比如非替換行內塊及非替換表格單元格,不是塊級盒。描述元素跟它的后代之間的影響。行盒行盒由行內格式化上下文產生的盒,用于表示一行。彈性容器外和彈性項目內的一切元素都不受影響。 CSS中各種布局的背后,實質上是各種*FC的組合。CSS2.1 中只有 BFC 和 IFC, CSS3 中還增加了 FFC 和 GFC。 盒模型(Box M...
摘要:塊級盒參與塊格式化上下文。行內級盒參與行內格式化上下文塊格式化上下文行內格式化上下文相對定位浮動盒就是一個在當前行向左或向右移動的盒。浮動絕對定位絕對定位模型中,一個盒會有相對于其包含塊的明確偏移,它會從常規流中全部移除不會影響后面的兄弟。 在可視化格式模型(Visual formatting model)當中,文檔樹中的每個元素根據其盒模型生成0個或多個盒.這些盒的布局由(以下因素)...
閱讀 2638·2021-11-25 09:43
閱讀 2740·2021-11-04 16:09
閱讀 1656·2021-10-12 10:13
閱讀 891·2021-09-29 09:35
閱讀 892·2021-08-03 14:03
閱讀 1785·2019-08-30 15:55
閱讀 3001·2019-08-28 18:14
閱讀 3502·2019-08-26 13:43