摘要:標(biāo)準(zhǔn)盒模型下,設(shè)置的的值后,這個值僅包含的寬高,而在盒模型下,這個值是后的寬高。例標(biāo)準(zhǔn)盒模型下,占據(jù)的實際寬為實際高度同理。對齊所處行內(nèi)框盒子的頂部對齊所處行內(nèi)框盒子的底部。
盒模型
盒模型之所以稱為“盒”是因為在一個頁面布局中,文檔中的每一個元素(塊級元素)均呈現(xiàn)為一個矩形的“盒子”,這個“盒子”包含:內(nèi)容(content) + 內(nèi)邊距(padding) + 邊框(border) + 外邊距(padding),如圖:
圖引自"https://developer.mozilla.org..."
盒模型又分為標(biāo)準(zhǔn)盒子模型和IE盒子模型。標(biāo)準(zhǔn)盒模型下,設(shè)置box的width的值后,這個值僅包含content的寬高,而在IE盒模型下,這個值是content + padding + border 后的寬高。例:
.test1{ width: 200px; height: 200px; padding: 50px; border: 10px dotted red; }
標(biāo)準(zhǔn)盒模型下,test1占據(jù)的實際寬為: border-left-width + padding-left + width +
padding-right + border-right-width = 320px; 實際高度同理。
而在IE盒模型下,test1占據(jù)的實際寬為 200px; 而content部分的實際寬度為: width -
border-left-width - padding-left - padding-right - border-right-width = 80px; content部分實際高度同理。
IE6+ 的瀏覽器默認(rèn)采用的均為標(biāo)準(zhǔn)盒模型,隨著ie6-的淘汰,標(biāo)準(zhǔn)/IE盒模型問題已經(jīng)不再成為問題。
在實際開發(fā)過程中,寬度為百分比時常常因為1px的border使得寬度不可控,此時可以使用box-sizing: border-box; 來對特定元素應(yīng)用IE盒模型,從而使得border和padding值被包含在設(shè)置的寬高內(nèi)。
行內(nèi)框盒子模型(line-boxes)對于上文的盒模型的解釋中,加了一個限制是指塊級元素,對于行內(nèi)元素,在頁面布局結(jié)構(gòu)中,同樣會呈現(xiàn)為一個矩形的盒子,但是這個盒子是無法定義寬度和高度,行內(nèi)元素的這個盒子我們可以成為行內(nèi)框盒子,行內(nèi)框盒子的寬度和高度分別是緊貼著行內(nèi)元素四周的寬和高。例如:
圖中文字白色區(qū)域就是行內(nèi)框盒子,白色區(qū)域的寬和高就是行內(nèi)框盒子的寬和高,這里設(shè)置的文字大小為60px; 7個字,因此行內(nèi)框盒子的寬高即為 420 X 60 ;
在說到行內(nèi)框盒子時,通常會提起幾個屬性,line-height和vertal-align。
Line-heightline-height的意義在于指定行內(nèi)框盒子的高度,對于塊級元素,line-height指定的是塊級元素內(nèi)部line-boxes的最小高度,對于非替代行內(nèi)元素,line-height用于計算行內(nèi)框盒子的高度,對于替代行內(nèi)元素,line-height多數(shù)時間是沒有影響的。
line-height的取值可以為 具體值/數(shù)字/百分比。
具體值:這個沒有疑問,設(shè)置多少就是多少,不過一般不推薦。
數(shù)字:實際的line-height的值為 當(dāng)前字體 * 數(shù)字 ,比如font-size: 60px; line-height: 1.5;
等同于line-height: 90px;
百分比:計算方式和數(shù)字是一樣的,比如font-size: 60px; line-height: 150%; 等同于line-height:
90px;
line-height具有繼承性,不過數(shù)字和百分比的繼承方式是不一樣的,數(shù)字是繼承的數(shù)字值,然后子元素再拿當(dāng)前font-size 數(shù)字,而百分比是依父元素的font-size 百分比,計算后把結(jié)果的帶單位的具體值繼承下去。例:
數(shù)字: 父元素:`.test1{font-size: 20px; line-height: 1.5;}` 子元素:`.test2{font-size: 60px;}`
父元素實際line-height為 1.5 * 20 px 即30px;
子元素實際line-height之繼承父元素計算前的值,1.5,因此子元素實際line-height為 1.5 * 60 px 即90px;
百分比: 父元素:`.test1{font-size: 20px; line-height: 150%;}` 子元素:`.test2{font-size: 60px;}`
父元素實際line-height為 150% * 20 px 即30px;
子元素實際line-height直接繼承父元素計算后的結(jié)果,即30px;
瀏覽器默認(rèn)的line-height值為normal,W3C解釋為 設(shè)置合理的行間距;MDN解釋為取決于用戶代理和元素的font-family,一般通常默認(rèn)為1.2左右。在上圖的例子中,在chrome下采用的是楷體,line-height測算為1.14。在最上面的圖中,我們未設(shè)置line-height的值,但是可以看得到文字上邊緣后是有一條縫隙的,這就是所謂的合理的行間距的結(jié)果。
然而,實際上,行內(nèi)框盒子模型的高度和line-height沒有關(guān)系,并且在上圖中我們也可以發(fā)現(xiàn),行內(nèi)框盒子在布局中占據(jù)的高度實際上是有l(wèi)ine-height決定的,當(dāng)line-height為0時,這個行框盒子就不再占用頁面布局的位置了,除了層級關(guān)系的相互遮蓋,這個行內(nèi)框盒子就不會影響其他元素的布局了,事實是這樣的嗎。例:
事實上我們發(fā)現(xiàn),紅色的test2,上邊緣的其實位置并不是父級(0,0)的位置,也就是說,我們的行框盒子實際還是占據(jù)了一部分位置,這個其實和vertal-align有關(guān)的。
Tips: 替代行內(nèi)元素指的是值根據(jù)元素的不同屬性來決定元素的具體顯示內(nèi)容,比如input type="text/button/file"等,其他的如:object/video/textarea/img等,某些情況下canvas和audio也可能是替換元素。Vertal-align
vertal-align是用來指定行內(nèi)元素(inline)或表格單元格(table-cell)元素的垂直對齊方式。vertal-align的取值有主要有:baseline/top/middle/bottom/sub/super/text-top/text-bottom/百分比/具體值。先來了解一下各個值對應(yīng)的位置。
baseline: 默認(rèn)值,自身的baseline和父級盒子的baseline對齊,如果沒有自身baseline(比如img),則外邊距底部邊緣和父級的baseline對齊;
middle: 自身垂直中點(diǎn)對齊 父級baseline + x 高度的一半 的位置;
百分比: 在baseline的基礎(chǔ)上,向上(百分比為正)或者向下(百分比為負(fù))偏移 line-height * 百分比 的值;
具體值:在baseline的基礎(chǔ)上,向上(值為正)或者向下(值為負(fù))偏移 這個值的距離;
top和bottom是兩個比較特殊的取值,使元素與行框盒子的邊界對齊而不是參考基線。
top: 對齊所處行內(nèi)框盒子的頂部;
bottom: 對齊所處行內(nèi)框盒子的底部。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/116455.html
摘要:標(biāo)準(zhǔn)盒模型下,設(shè)置的的值后,這個值僅包含的寬高,而在盒模型下,這個值是后的寬高。例標(biāo)準(zhǔn)盒模型下,占據(jù)的實際寬為實際高度同理。對齊所處行內(nèi)框盒子的頂部對齊所處行內(nèi)框盒子的底部。 盒模型 盒模型之所以稱為盒是因為在一個頁面布局中,文檔中的每一個元素(塊級元素)均呈現(xiàn)為一個矩形的盒子,這個盒子包含:內(nèi)容(content) + 內(nèi)邊距(padding) + 邊框(border) + 外邊距(p...
摘要:中各種布局的背后,實質(zhì)上是各種的組合。相反,一些塊容器盒,比如非替換行內(nèi)塊及非替換表格單元格,不是塊級盒。描述元素跟它的后代之間的影響。行盒行盒由行內(nèi)格式化上下文產(chǎn)生的盒,用于表示一行。彈性容器外和彈性項目內(nèi)的一切元素都不受影響。 CSS中各種布局的背后,實質(zhì)上是各種*FC的組合。CSS2.1 中只有 BFC 和 IFC, CSS3 中還增加了 FFC 和 GFC。 盒模型(Box M...
摘要:在文檔中,元素被表示為一個矩形的盒子。在中,使用盒模型描述這些矩形盒子中的每一個。規(guī)定以具體單位計的內(nèi)邊距值,比如像素厘米等。但不允許使用負(fù)值。實際測試的百分比,測試結(jié)果并不是等于,而是近似等于。 在文檔中,元素被表示為一個矩形的盒子。 在CSS中,使用盒模型描述這些矩形盒子中的每一個。這個模型描述了元素所占空間的內(nèi)容。每個盒子有四個邊:外邊距邊(margin), 邊框邊(border...
摘要:垂直格式化,有一個很重要的方面是會造成垂直相鄰?fù)膺吘嗪喜?,解決這個的方式見想要清晰的明白一中的部分。參考資料權(quán)威指南第三版為負(fù)值產(chǎn)生的影響和常見布局應(yīng)用布局圣杯布局雙飛翼布局深入理解和的基友關(guān)系深入理解中的行高 在上一篇想要清晰的明白(一): CSS視覺格式化模型|盒模型|定位方案|BFC比較宏觀的了解了盒子模型的作用,接下來就詳細(xì)的介紹兩種盒子的具體細(xì)節(jié) Block Box show...
摘要:并且這種過程遵循標(biāo)準(zhǔn)的描述只要不是和絕對定位方式布局的,都在普通流里面。定位相對定位在普通流之中,是相對于它在普通流中的位置中進(jìn)行移動,元素占據(jù)原來位置絕對定位脫離普通流,不占據(jù)空間相對于距離它最近的那個已定位的祖先相對絕對元素決定的。 視覺格式化模型 頁面(文檔樹)可以想象成是由一個個的Box組合而成的,而視覺格式化模型(Visual formatting model)是一套規(guī)則,將...
閱讀 1808·2021-09-03 10:50
閱讀 1338·2019-08-30 15:55
閱讀 3380·2019-08-30 15:52
閱讀 1242·2019-08-30 15:44
閱讀 952·2019-08-30 15:44
閱讀 3325·2019-08-30 14:23
閱讀 3559·2019-08-28 17:51
閱讀 2298·2019-08-26 13:52