成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

CSS盒模型 - 官方文檔總結(jié)

plus2047 / 3219人閱讀

摘要:盒子的概念盒子模型指的是瀏覽器將文檔流從視覺(jué)上渲染為不同矩形框的組合。瀏覽器將文檔流中的每個(gè)元素都渲染為一個(gè)矩形框,其包含內(nèi)容區(qū)域如文本圖片和可選的三個(gè)區(qū)域,中文名為外邊距邊框和填充。注意只有普通文檔流中塊框的垂直外邊距才會(huì)發(fā)生外邊距合并。

一直對(duì)盒模型的了解很零碎,學(xué)習(xí)都來(lái)源于各個(gè)文章的只言片語(yǔ),這樣學(xué)來(lái)的既不完善,也不持久。最近通讀了w3的官方文檔,對(duì)其中的內(nèi)容進(jìn)行一點(diǎn)歸納吧。

盒子的概念

盒子模型指的是瀏覽器將文檔流從視覺(jué)上渲染為不同矩形框的組合。
瀏覽器將文檔流中的每個(gè)元素都渲染為一個(gè)矩形框,其包含內(nèi)容區(qū)域(如文本、圖片)和可選的margin/border/padding三個(gè)區(qū)域,中文名為外邊距、邊框和填充。如下圖所示:

這四個(gè)區(qū)域每一個(gè)都可以劃分為上下左右4個(gè)部分的邊界,如上邊距、下邊距,上邊框、下邊框等。

內(nèi)容邊界:包裹著元素寬度和高度確定的盒子的四個(gè)線段組成。
填充邊界:包裹著元素填充區(qū)域的四個(gè)線段組成,如果填充寬度為0,則等于內(nèi)容邊界。
邊框邊界:包裹著元素邊框區(qū)域的四個(gè)線段組成,如果邊框?qū)挾葹?,則等于填充邊界。
外邊距邊界:包裹著元素外邊距區(qū)域的四個(gè)線段組成,如果外邊距寬度為0,則等于外邊距邊界。

其中內(nèi)容區(qū)域的盒子的寬度和高度由幾個(gè)因素來(lái)進(jìn)行確定,是否設(shè)置了寬度和高度值,是否包含文本內(nèi)容或者其他的盒子,盒子類型是否為table相關(guān)等等。
內(nèi)容和填充區(qū)域的顏色由background屬性來(lái)設(shè)置,邊框區(qū)域的顏色由border-color || color其中一個(gè)屬性來(lái)設(shè)置,外邊距區(qū)域的顏色為transparent透明色。

實(shí)例

下面的插圖展示了margin/border/padding如何被渲染(圖二是更為詳細(xì)的切分):



  
    Examples of margins, padding, and borders
    
  
  
    
  • First element of list
  • Second element of list is a bit longer to illustrate wrapping.

需要注意的是:

內(nèi)容區(qū)域的計(jì)算是自上而下的,所有的li元素的內(nèi)容區(qū)域計(jì)算都基于ul父元素。

margin盒子包含了content/padding/border/margin四部分的總和,在縱向上會(huì)出現(xiàn)margin的合并。

margin的顏色總是透明的,所以顏色會(huì)是父元素的透射顏色。

margin屬性

margin屬性包括margin-top/margin-right/margin-bottom/margin-left 和 margin。

margin-top/margin-right/margin-bottom/margin-left
值: || inherit || auto
初始值: 0
適用于:除了table展示類型的所有元素,table類型里依然適用的有`table-caption/table/inline-table`
繼承: 否
百分比:根據(jù)父包裹容器的寬度
計(jì)算值:指定的百分比或固定值

需要注意:margin-top/margin-bottom屬性對(duì)行間元素不起作用。
如果使用auto,同時(shí)父元素具有對(duì)應(yīng)的寬度和高度,將在計(jì)算時(shí)均分空余空間達(dá)到居中的效果。

margin是以上四種屬性的簡(jiǎn)寫,如果只有一個(gè)值,則設(shè)置所有邊界;兩個(gè)值則第一個(gè)值為top/bottom值,第二個(gè)值為left/right值;三個(gè)值則第一個(gè)值為top值,第二個(gè)值為left/right值,第三個(gè)為bottom值;四個(gè)值則分別對(duì)應(yīng)top/right/bottom/left四個(gè)邊界。

body { margin: 2em }         /* all margins set to 2em */
body { margin: 1em 2em }     /* top & bottom = 1em, right & left = 2em */
body { margin: 1em 2em 3em } /* top=1em, right=2em, bottom=3em, left=2em */
margin的邊界合并

在CSS里,兩個(gè)相鄰元素(并不一定是兄弟元素)的外邊距將會(huì)發(fā)生合并為一個(gè)外邊距,這個(gè)過(guò)程我們成為collapse。這個(gè)過(guò)程只會(huì)發(fā)生在垂直方向上的margin,合并結(jié)果是所有外邊距的最大值。
邊界合并的設(shè)置是為了元素布局的合理展示,如段落間的距離不會(huì)成為頂部的兩倍。
邊界的合并適用于margin-top/margin-bottom,不僅僅包括兄弟元素的合并,還有父子元素甚至自身的上下邊距合并。
注意:只有普通文檔流中塊框的垂直外邊距才會(huì)發(fā)生外邊距合并。行內(nèi)框、浮動(dòng)框或絕對(duì)定位之間的外邊距不會(huì)合并。
下圖展示margin合并的效果圖(來(lái)源于w3school文檔):
兄弟元素外邊距合并:

父子元素外邊距合并:

自身元素外邊距合并:

另外官方文檔里關(guān)于合并還有很多的特殊情況,不再一一說(shuō)明,粘貼源文檔:

Adjoining vertical margins collapse, except:

Margins of the root element"s box do not collapse.
If the top and bottom margins of an element with clearance are adjoining, its margins collapse with the adjoining margins of following siblings but that resulting margin does not collapse with the bottom margin of the parent block.
Horizontal margins never collapse.

Two margins are adjoining if and only if:

both belong to in-flow block-level boxes that participate in the same block formatting context

no line boxes, no clearance, no padding and no border separate them (Note that certain zero-height line boxes (see 9.4.2) are ignored for this purpose.)
both belong to vertically-adjacent box edges, i.e. form one of the following pairs:
 - top margin of a box and top margin of its first in-flow child
 - bottom margin of box and top margin of its next in-flow following sibling
 - bottom margin of a last in-flow child and bottom margin of its parent if the parent has "auto" computed height
 - top and bottom margins of a box that does not establish a new block formatting context and that has zero computed "min-height", zero or "auto" computed "height", and no in-flow children

A collapsed margin is considered adjoining to another margin if any of its component margins is adjoining to that margin.

Note. Adjoining margins can be generated by elements that are not related as siblings or ancestors.

Note the above rules imply that:

 - Margins between a floated box and any other box do not collapse (not even between a float and its in-flow children).
 - Margins of elements that establish new block formatting contexts (such as floats and elements with "overflow" other than "visible") do not collapse with their in-flow children.
 - Margins of absolutely positioned boxes do not collapse (not even with their in-flow children).
 - Margins of inline-block boxes do not collapse (not even with their in-flow children).
 - The bottom margin of an in-flow block-level element always collapses with the top margin of its next in-flow block-level sibling, unless that sibling has clearance.
 - The top margin of an in-flow block element collapses with its first in-flow block-level child"s top margin if the element has no top border, no top padding, and the child has no clearance.
 - The bottom margin of an in-flow block box with a "height" of "auto" and a "min-height" of zero collapses with its last in-flow block-level child"s bottom margin if the box has no bottom padding and no bottom border and the child"s bottom margin does not collapse with a top margin that has clearance.
 - A box"s own margins collapse if the "min-height" property is zero, and it has neither top or bottom borders nor top or bottom padding, and it has a "height" of either 0 or "auto", and it does not contain a line box, and all of its in-flow children"s margins (if any) collapse.

When two or more margins collapse, the resulting margin width is the maximum of the collapsing margins" widths. In the case of negative margins, the maximum of the absolute values of the negative adjoining margins is deducted from the maximum of the positive adjoining margins. If there are no positive margins, the maximum of the absolute values of the adjoining margins is deducted from zero.

If the top and bottom margins of a box are adjoining, then it is possible for margins to collapse through it. In this case, the position of the element depends on its relationship with the other elements whose margins are being collapsed.

If the element"s margins are collapsed with its parent"s top margin, the top border edge of the box is defined to be the same as the parent"s.
Otherwise, either the element"s parent is not taking part in the margin collapsing, or only the parent"s bottom margin is involved. The position of the element"s top border edge is the same as it would have been if the element had a non-zero bottom border.
Note that the positions of elements that have been collapsed through have no effect on the positions of the other elements with whose margins they are being collapsed; the top border edge position is only required for laying out descendants of these elements.

順便講一個(gè)常見的bug:垂直外邊距合并問(wèn)題常見于第一個(gè)子元素的margin-top會(huì)頂開父元素與父元素相鄰元素的間距。其原因?yàn)楦冈睾偷谝粋€(gè)子元素的外邊距進(jìn)行合并,并選取其最大值,即第一個(gè)元素的上邊距,導(dǎo)致?lián)伍_父元素上邊距。解決方案為:設(shè)置父元素的border或padding將子元素控制在父元素content內(nèi)部,防止發(fā)生margin合并,即給外部div設(shè)置一個(gè)透明的1像素的border-top即可。

.outer-box{
  border-top:1px solid transparent;
}
Padding屬性

padding屬性包括padding-top/padding-right/padding-bottom/padding-left 和 padding

padding-top/padding-right/padding-bottom/padding-left
值: || inherit
初始值: 0
適用于:除了`table-row-group/table-header/group/table-footer-group/table-row/table-column-group/table-column`的所有元素
繼承: 否
百分比:根據(jù)父包裹容器的寬度
計(jì)算值:指定的百分比或固定值

需要注意:margin-top/margin-bottom屬性對(duì)行間元素不起作用,且值不能為負(fù)。

margin是以上四種屬性的簡(jiǎn)寫,設(shè)置的內(nèi)容和上面一致,元素的個(gè)數(shù)和含義與margin相同。

border屬性

border屬性包括border-width/border-color/border-style,而其中每一個(gè)都可以切分為4塊,如border-left-width/border-top-color。對(duì)于不同的用戶代理(瀏覽器)會(huì)對(duì)部分的元素渲染出特定的樣式來(lái),如button,menus等。

border-top-width等
值: || inherit || thin || medium || thick
初始值: medium
適用于:所有元素
繼承: 否
百分比:N/A,無(wú)法設(shè)置
計(jì)算值:絕對(duì)值,如果為none/hidden則轉(zhuǎn)換為0

需要注意:thin/medium/thick由不同的瀏覽器實(shí)現(xiàn),具體的值不盡相同。

border-top-color等
值: || transparent || inherit
初始值: color的值(字體顏色)
適用于:所有元素
繼承: 否
百分比:N/A,無(wú)法設(shè)置
計(jì)算值:指定的值或者字體顏色color的值
border-top-style等
值:none || hidden || dotted || dashed || solid || double || groove || ridge || inset || outset || inherit
初始值: none
適用于:所有元素
繼承: 否
百分比:N/A,無(wú)法設(shè)置
計(jì)算值:指定的值

需要注意:邊框會(huì)繪制在所有盒子背景色的上方,在groove/ridge/inset/outset值時(shí),具體的顏色可能會(huì)被瀏覽器強(qiáng)制修改,而不僅限于border-color屬性。初始值為none,所以一定要進(jìn)行設(shè)置樣式,否則看不到。

border屬性:    [  ||  || <"border-top-color"> ] || inherit

需要注意:border屬性不能像其中三個(gè)子屬性一樣分別設(shè)置,如果設(shè)置其中一個(gè)值,則會(huì)應(yīng)用到所有四條邊界上。

margin是以上四種屬性的簡(jiǎn)寫,設(shè)置的內(nèi)容和上面一致,元素的個(gè)數(shù)和含義與margin相同。

下面的兩段樣式只是出現(xiàn)的順序不同會(huì)顯示出不同的效果來(lái),原因是設(shè)置的順序影響到值的覆蓋:

// 左邊框?yàn)殡p細(xì)線和黑色
blockquote {
  border: solid red;
  border-left: double;
  color: black;
}
// 邊框全部為實(shí)線和紅色
blockquote {
  border-left: double;
  color: black;
  border: solid red;
}
雙向上下文的行間元素的盒模型

在每一個(gè)行間元素中,瀏覽器需要產(chǎn)生每一個(gè)盒子按照視覺(jué)順序而非邏輯順序(也就是direction設(shè)置的方向)進(jìn)行渲染。
下面的兩句話我實(shí)在是看不懂在講什么,貼出原文:

When the element"s "direction" property is "ltr", the left-most generated box of the first line box in which the element appears has the left margin, left border and left padding, and the right-most generated box of the last line box in which the element appears has the right padding, right border and right margin.

When the element"s "direction" property is "rtl", the right-most generated box of the first line box in which the element appears has the right padding, right border and right margin, and the left-most generated box of the last line box in which the element appears has the left margin, left border and left padding.
盒模型相關(guān)的周邊問(wèn)題

inline-block元素之間的小空白

 

 
  
第一個(gè)元素 第二個(gè)元素

效果入圖:

原因?yàn)椋篐TML 中的換行符、空格符、制表符等合并為空白符, 字體大小不為 0 的情況下, 空白符自然占據(jù)一定的寬度, 因此產(chǎn)生了元素間的空隙.
解決方案:可以為inline-block元素設(shè)置為負(fù)的margin-left; 或父元素font-size設(shè)置為0, 子元素再重新設(shè)置回來(lái)等方法。
推薦方案:直接在HTML文檔里改變文本排列,使行間元素尾標(biāo)簽和下一個(gè)頭便簽間不留任何空格,如

第一個(gè)元素第二個(gè)元素

因?yàn)檫@樣影響范圍最小,不需任何額外代碼。

參考文獻(xiàn)

w3c官網(wǎng)文檔 - 盒子模型:https://www.w3.org/TR/CSS2/bo...

你不知道的margin屬性:http://louiszhai.github.io/20...元素之間空白Bug

w3school - CSS外邊距合并:http://www.w3school.com.cn/cs...

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/112615.html

相關(guān)文章

  • 模型的一些碎碎念

    摘要:盒模型的簡(jiǎn)介本文簡(jiǎn)單的總結(jié)了一些基本概念,知識(shí)點(diǎn)以及細(xì)節(jié)問(wèn)題作為前端人員,盒模型是最基礎(chǔ)的知識(shí)點(diǎn),在排版與布局時(shí)不可避免與盒模型打交道。 1. 盒模型的簡(jiǎn)介 本文簡(jiǎn)單的總結(jié)了一些基本概念,知識(shí)點(diǎn)以及細(xì)節(jié)問(wèn)題 作為前端人員,盒模型是最基礎(chǔ)的知識(shí)點(diǎn),在排版與布局時(shí)不可避免與盒模型打交道。 在我們編寫HTML時(shí),網(wǎng)頁(yè)上的內(nèi)容幾乎都是被包在一個(gè)個(gè)元素(當(dāng)然也可以叫做標(biāo)簽)中的,最常見的有div...

    王偉廷 評(píng)論0 收藏0
  • 前端面試之CSS總結(jié)(上)

    摘要:重點(diǎn)介紹一下常見的三列布局之圣杯布局和雙飛翼布局。兩種布局方式的不同之處在于如何處理中間主列的位置圣杯布局是利用父容器的左右內(nèi)邊距定位雙飛翼布局是把主列嵌套在后利用主列的左右外邊距定位。 CSS總結(jié) 由于最近在準(zhǔn)備前端方面的面試,所以對(duì)自己平常工作中用到的地方做出一些總結(jié)。該篇是CSS部分(上),有許多地方敘述的并不是十分詳細(xì),只是大致的描述一下,給自己提供一個(gè)知識(shí)輪廓。本篇中主要描述...

    ?。琛?/span> 評(píng)論0 收藏0
  • CSS規(guī)范 > 8 模型 Box Model

    摘要:當(dāng)兩個(gè)及以上外邊距折疊,合并后的外邊距寬度是發(fā)生折疊的外邊距中的最大寬度。如果該元素的外邊距同其父元素的上外邊距折疊,則該盒的上邊框邊緣同其父元盒的上邊框邊緣相同。 2017-07-20: 關(guān)于外邊距折疊, 推薦問(wèn)題: https://segmentfault.com/q/10... 8 盒模型 Box Model URL: http://www.w3.org/TR/CSS2/box...

    suemi 評(píng)論0 收藏0
  • 內(nèi)聯(lián)元素的模型 display和visibility overflow 文檔

    摘要:筆記從尚硅谷的第講開始的內(nèi)聯(lián)元素的盒模型,此套視頻是第二遍看,為了以后不再看第三遍,把重要的知識(shí)做個(gè)總結(jié)。其實(shí)我們的元素天生就有這種效果。是元素的默認(rèn)值,也是設(shè)置元素為隱藏,但是它隱藏后還會(huì)占用頁(yè)面的布局。以上只是在正常的文檔流中 筆記從尚硅谷html+css的第54講開始的內(nèi)聯(lián)元素的盒模型,此套視頻是第二遍看,為了以后不再看第三遍,把重要的知識(shí)做個(gè)總結(jié)。 54講 內(nèi)聯(lián)元素的盒模型 內(nèi)...

    bovenson 評(píng)論0 收藏0
  • 內(nèi)聯(lián)元素的模型 display和visibility overflow 文檔

    摘要:筆記從尚硅谷的第講開始的內(nèi)聯(lián)元素的盒模型,此套視頻是第二遍看,為了以后不再看第三遍,把重要的知識(shí)做個(gè)總結(jié)。其實(shí)我們的元素天生就有這種效果。是元素的默認(rèn)值,也是設(shè)置元素為隱藏,但是它隱藏后還會(huì)占用頁(yè)面的布局。以上只是在正常的文檔流中 筆記從尚硅谷html+css的第54講開始的內(nèi)聯(lián)元素的盒模型,此套視頻是第二遍看,為了以后不再看第三遍,把重要的知識(shí)做個(gè)總結(jié)。 54講 內(nèi)聯(lián)元素的盒模型 內(nèi)...

    JessYanCoding 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<