国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

理解 line-height 和 vertical-align

jzzlee / 611人閱讀

摘要:我認為應該將理解為。如果的值是,高度就是等于。中所有的最高點以及最低點決定了它的高度該計算包括了的高度,后文會提到。非替換元素的的,以及并不會影響高度的計算。并不是兩條之間的距離。元素的垂直中點位置與父元素的基線加上一半的位置對齊。

文章 GitHub 地址:https://github.com/afishhhhh/blog/issues/4
文章如有錯誤,請各位能夠指出。

幾個概念

line box:包裹 inline box 的一個盒子,一個或多個 line box 堆疊撐起一個 HTML 元素。

inline(-level) box:可以是一個由行內元素包裹的盒子,也可以是一個純文字的匿名盒子。

content area:對于非替換元素來說,content area 的范圍由 font-size 以及字體本身決定;對于替換元素來說,由元素自有寬高決定。

baseline:一個元素基線的位置由該元素內字母 x 底部所在的位置決定,當然字體不同基線所在的位置也就不同。

通過一段代碼可以理解一下:

div {
  background-color: #ccc;
  font-size: 20px;
  color: #fff;
}
span {
  color: red;
}
文字1文字2文字3

白色的文字就是一個匿名 inline box,紅色的文字是一個由 span 包裹的 inline box。這三個 inline box 組成一個 line box,可以理解為灰色的區域,因為在這個例子里就是由一個 line box 撐開了 div。如果有多行的文字,那就有多個 line box

關于 content areaW3C 有一段這樣的解釋:

CSS 2.1 does not define what the content area of an inline box is (see 10.6.1 above) and thus different UAs may draw the backgrounds and borders in different places.

這篇文章對非替換元素 content area 的定義就是自有寬高加上 margin,padding 以及 border。我認為應該將 content area 理解為 content box

line box 高度

瀏覽器會計算 line box 中每一個 inline box 的高度,對于不同的 inline box 計算方式有所不同:

如果是一個替換元素(比如 imginput),inline-* 元素或者是 flexbox 中的子元素,高度由其 margin box 決定;

inline-block 元素:

div {
  background-color: #ccc;
  color: #fff;
}
span {
  display: inline-block;
  height: 30px;
  margin: 10px;
  background: #fff;
  color: red;
}
xxxxxxxxx

這里 span inline box 的高度就是 height + margin 2。如果 height 的值是 auto,高度就是等于 line-height + margin 2

如果是一個非替換元素,高度由它的 line-height 決定,而不是 content area,雖然有時候看起來像 content area 撐開了 line box 的高度。

div {
  background-color: #ccc;
  font-size: 20px;
  color: #fff;
  font-family: Sana;
}
span {
  background: #fff;
  color: red;
}
xxxxxxxxx

這張圖片可以明顯地看出撐開 line box 的是 line-height,而不是 content area

這篇文章用了 virtual-area height 來表示 line-height 撐開的高度,而我的理解其實就是 inline box 的高度。

line box 中所有 inline box 的最高點以及最低點決定了它的高度(該計算包括了 strut 的高度,后文會提到 strut)。

非替換元素的的 marginpadding 以及 border 并不會影響 line box 高度的計算。當一個 inline-level boxline-height 小于 content area 的時候,line box 的高度就會小于 content area,此時元素的 background 以及 padding 等就會溢出到 line box 之外。

以下代碼可以說明這個問題:

div {
    background: #eee;
    border: 1px solid #000;
    box-sizing: border-box;
    font-size: 50px;
    line-height: 10px;
}
span {
    background: red;
    margin: 10px;
    padding: 10px;
}
xxx

leading:

content area 的高度與 inline box 的高度差就是 leading,這個 leading 會等分被添加到 content area 的頂部與底部,所以說 content area 永遠位于 inline box 的中間(垂直居中)

strut:

瀏覽器認為每一個 line box 的起始位置都存在一個寬度為 0,沒有任何字符的 匿名 inline box,稱為 strut,這個 strut 是會從父元素繼承 line-height 的,因此它的高度會影響整個 line box 高度的計算。

一個例子

div { background: #eee; border: 1px solid #000; box-sizing: border-box; }

在圖片中可以看到 img 與外層的 div 存在一個間隙,這就是上文提到的 strut 造成的。

在這個例子中,默認情況下 img 的底邊與父元素的基線對齊(img { vertical-align: baseline }),而這個基線實際上就是 strut 基線所在的位置。如下圖所示:


strut 其實就相當于一個不可見的字母 x,上文已經提到 strut 本身是具有 line-height 的,所以就導致圖片底部多了一段間隙。

總結一下存在間隙原因:

strut 存在 line-height

vertical-align 默認值為 baseline

對應的解決方案:

修改 strutline-height,因為 strutline-height 不是能夠直接設置的,所以需要設置父元素的 line-height,然后讓 strut 繼承,或者修改 font-size

vertical-align 設置為其他值

line-height

W3C 中對于 line-height 的解釋是這樣的:

On a block container element whose content is composed of inline-level elements, "line-height" specifies the minimal height of line boxes within the element. The minimum height consists of a minimum height above the baseline and a minimum depth below it, exactly as if each line box starts with a zero-width inline box with the element"s font and line height properties. We call that imaginary box a "strut."

我的簡單理解是,對于由行內元素組成的塊級元素而言,line-height 決定了 line box 的最小高度,瀏覽器會假定每一個 line box 以一個寬度為 0 的 inline boxstrut)開始,而這個 strut 從父元素繼承到 font 以及 line-height

normalline-height 的默認值,W3C 對它并沒有一個明確的定義。normal 會將 content area 作為一個計算因素。

line-height 并不是兩條 baseline 之間的距離。

line-height 的值推薦使用數值,而不是使用 em 單位,因為 em 單位會根據從父元素繼承到的 font-size 來計算行高。

vertical-align

W3Cbaseline 以及 middle 的定義如下:

baseline: Align the baseline of the box with the baseline of the parent box. If the box does not have a baseline, align the bottom margin edge with the parent"s baseline.

元素基線與父元素基線對齊,如果元素沒有基線,比如 img,則使用 margin 底邊與父元素基線對齊。

middle: Align the vertical midpoint of the box with the baseline of the parent box plus half the x-height of the parent.

元素的垂直中點位置與父元素的基線加上一半 x-height 的位置對齊。

參考

Deep dive CSS: font metrics, line-height and vertical-align

https://meyerweb.com/eric/css/inline-format.html

https://www.zhangxinxu.com/wordpress/2015/08/css-deep-understand-vertical-align-and-line-height/

https://www.w3.org/TR/CSS2/visudet.html#inline-box-height

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/117128.html

相關文章

  • 深入理解css之vertical-align

    摘要:但實質上,只要是內聯元素,這兩個元素都會同時在起作用。而解決方案可以有以下幾種元素不使用基線對齊,可以改為對齊元素塊狀化設置為設置為總結講解了的各類屬性值及其效果起作用的前提是內聯元素與都是同時作用在內聯元素上的 前言 vertical-align用來指定行內元素(inline)或表格單元格(table-cell)元素的垂直對齊方式。也就是說,對于塊級元素,vertical-align...

    cgh1999520 評論0 收藏0
  • CSS魔法堂:深入理解line-heightvertical-align

    摘要:下的屬性值詳解以下內容均在中測試默認對齊方式這里作為參考系,而它的就是所要對齊的了。沒有任何變化。那改變又如何呢為了讓的清晰可見,特意添加一個的包裹著。 前言 一直聽說line-height是指兩行文本的基線間的距離,然后又說行高等于行距,最近還聽說有個叫行間距的家伙,@張鑫旭還說line-height和vertical-align基情四射,貴圈真亂啊。。。。。。于是通過本篇來一探究竟...

    avwu 評論0 收藏0
  • 【學習筆記】CSS深入理解vertical-align

    摘要:上例中,左邊盒子的基線為其底邊緣,右邊盒子的基線為的基線將右邊盒子的行高設置為,即這個的高度為,位置處于中間。 vertical-align的值 線類:baseline(默認), top, bottom, middle 文字類:text-top, text-bottom 上標下標類:sub, super 數值:1px, 1em - 在baseline對齊的基礎上上下偏移一定數值 百分...

    ermaoL 評論0 收藏0
  • 關于 vertical-align 的一些理解

    摘要:關于的條參考線以及。關于和之間的關系。目標元素的的垂直平分線,與父元素內匿名的對齊。垂直平分線,這個容易理解。要比這些字母的頂端再高一些。 前言 關于 vertical-align,我們很容易想到,這不就是告訴我們元素在縱向上和什么對齊的屬性嗎?而事實上,正是這種寬泛的說法導致了我們對其的理解存在許多不確定性。事實上,對齊這兩個字其實牽涉到4個對象:即哪個對象的哪條線,與哪個對象的哪條...

    lowett 評論0 收藏0
  • 深入理解 CSS:字體度量、line-height vertical-align

    摘要:接下來說句聽起來很奇怪的話一個內聯元素有兩個高度高度和實際區域高度是我自己發明的單詞,它表示對人類有效的高度,你在其他地方是看不到這個單詞的。你沒看錯,是計算的一些細節對于內聯元素,和會增大區域,但是不會增大不是的高度。 本文為饑人谷講師方方原創文章,首發于 前端學習指南。 這是一篇譯文,對 inline 和 inline-block 的元素剖析非常給力。 原文:Deep dive C...

    Dean 評論0 收藏0

發表評論

0條評論

jzzlee

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<