摘要:的應用大部分時候,我們設置,都是為了垂直居中對齊。然后我們給設置,這樣我們就可以重置設置的,又因為保持了內聯特性,因此我們可以設置以及產生,從而實現近似垂直居中對齊。
前言
行高,顧名思義是一行文字的高度,而從規范上來說則是兩行文字基線之間的距離。行高是作用在每一個行框盒子(line-box)上的,而行框盒子則是由內聯盒子組成,因此,行高與內聯元素可以說是非常緊密,行高直接決定了內聯元素的高度(注意:這里的內聯元素不包括替換元素);對于塊級元素和替換元素,行高是無法決定最終高度的,只能決定行框盒子的最小高度。
x、x-height以及ex字母x在css里面扮演著一個很重要的角色,因為字母x的下邊緣就是基線所在的位置。而x-height指的就是字母x的高度,ex是一個尺寸單位,其大小是相對字母x的來計算的,即1ex就表示1個字母x的高度。如下圖所示:
我們在平時的開發中很少用到ex,因為ex是個相對單位。對于相對的東西,我們總是感覺很難控制,但這并不表明ex就一點用處都沒有。我們可以利用ex就是一個x-height的特性來實現圖標與文字的垂直居中,這樣如論字體大小如何變化,都不會影響垂直居中的效果。代碼如下:
.icon-arrow { display: inline-block; width: 20px; height: 1ex; background: url(down.png) no-repeat center; background-size: contain; }
我是一段文本
效果如下:
line-height的屬性值normal
數字
長度
百分比
normalnormal為line-height的默認值,但并不是一個固定的值,而是會受font-family的影響,對于“微軟雅黑”,其值為1.32;而對于“宋體”,其值為1.141。由于不同操作系統,不同瀏覽器所使用的字體不一樣,所以最終line-height的具體值會不一樣,因此這個屬性作用不大。
數字我們可以設置line-height: 1.5。其意思是說line-height的最終大小為 1.5* font-size,一般建議使用該值來設置line-height。
長度長度用的最多的就是px與em,em跟數字一樣,都是相對于font-size來計算的。
百分比百分比也是相對于font-size來計算的。
相信細心的小伙伴已經發現了,數字,em以及百分比都是相對于font-size來計算的,既然這樣,為什么還要多此一舉設置另外兩個屬性呢。原因就在于它們的繼承方式是不一樣的。對于數字,父元素設置了1.5,則子元素也是會繼承1.5。但如果父元素設置的是1.5em,假設父元素font-size是20px,則父元素line-height是30px,同時子元素的line-height也是30px,也就是說子元素繼承的是父元素計算后的line-height值。因此,這也是為什么上面推薦使用數字而不是em或百分比的原因了。
行距與半行距很多開發人員開還原設計圖的時候,往往沒有考慮到行距的影響,因此開發出來的頁面很多時候都與設計圖不符合,總會差那么幾個像素。那么什么是行距呢,我們可以想象一下在文字排版的時候,如果行與行之間的間距為0,則文字是會緊緊貼在一起的,因此,行距就是用來協助排版的。行距的計算為:line-height - em-box,em-box指的是1em的大小,因此行距可以表示為:line-height - font-size,假設line-height為1.5,font-size為20,則行距為:
1.5*20 - 20 = 10,則最終行距為10,而這個行距會平均作用于文字的上邊和下邊。但em-box我們是無法感知這個盒子在哪的,而內容區域我們則可以理解為我們選中文字后的背景色所在區域,而當字體是宋體的時候,內容區域和em-box是等高的,因此我們可以利用此揪出ex-box的藏身之處。如下圖所示:
正是因為行距的存在,我們給元素設置margin值時,要減去相應的半行距值,這樣才能比較精確地還原設計圖。
line-height的應用大部分時候,我們設置line-height,都是為了垂直居中對齊。但這里的居中,只能說是近似居中,從上面的圖可以看出:行距是上下均分的,但是內容區域不是,一般來說,文字都是偏下的。我們平時設置字體一般都是12-20像素,這么小的像素值,給出line-height值后,由于上下相差不大,因此感覺上是垂直居中的。line-height除了可以作為單行文本的居中對齊外,多行文本也是可以的,代碼如下:
.box { width: 400px; line-height: 400px; padding: 0 10px; border: 1px solid #ccc; } .text { display: inline-block; line-height: 1.3; font-size: 14px; vertical-align: middle; }
這是一段很長很長的文字,這是一段很長很長的文字,這是一段很長很長的文字,這是一段很長很長的文字,這是一段很長很長的文字
效果如下:
前面的文章有說過,每一個行框盒子前面都有一個看不見的,規范稱之為“strut”的東西。我們給.box設置了line-height為400px,則這個“strut”的line-height也會繼承為400px。然后我們給.text設置inline-block,這樣我們就可以重置.box設置的line-height,又因為ineline-block保持了內聯特性,因此我們可以設置vertical-align以及產生“strut”,從而實現近似垂直居中對齊。
總結介紹了字母x在css中的地位以及ex的應用
line-height各種不同的屬性值以及數字、em和百分比的不同之處
行距在line-height的作用
line-height實現單行垂直居中和多行垂直居中
參考:
《css世界》
https://developer.mozilla.org...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/113312.html
摘要:內聯盒子的高度由決定,限制包含盒子的高度,兩者一致,即把內聯盒子安放在包含盒子內,排除其他外界干擾。這時候由內聯盒子模型可知,行間距是等分的,中間部分是,達到看似居中的效果。可以得到結論和設置一致,并非是完全垂直,除非為。 張鑫旭的CSS深入理解之line-height學習筆記 line-height的定義 行高:兩行文字基線之間的距離 為何是基線:基線是定義所有字線的根本 不同字體...
摘要:按照定義來解釋,就是兩行文字之間基線之間的距離。了解完基線的定義后,我們接著來聊行高。上面我們說過,行高就是兩條基線的之間的距離,如下圖所示。 1.寫在前面 兩個多周的時間沒有寫文章了,手好癢好癢,趁著公司在裝修,從上周末到本周都在家辦公,同時公司的項目并不緊急,于是抽著時間梳理了一下CSS中關于行高line-height的理解,今天發布出來,大家準備好了嗎? 2.基本概念 2.1行高...
摘要:但實質上,只要是內聯元素,這兩個元素都會同時在起作用。而解決方案可以有以下幾種元素不使用基線對齊,可以改為對齊元素塊狀化設置為設置為總結講解了的各類屬性值及其效果起作用的前提是內聯元素與都是同時作用在內聯元素上的 前言 vertical-align用來指定行內元素(inline)或表格單元格(table-cell)元素的垂直對齊方式。也就是說,對于塊級元素,vertical-align...
摘要:上例中,左邊盒子的基線為其底邊緣,右邊盒子的基線為的基線將右邊盒子的行高設置為,即這個的高度為,位置處于中間。 vertical-align的值 線類:baseline(默認), top, bottom, middle 文字類:text-top, text-bottom 上標下標類:sub, super 數值:1px, 1em - 在baseline對齊的基礎上上下偏移一定數值 百分...
閱讀 1989·2021-09-07 10:24
閱讀 2092·2019-08-30 15:55
閱讀 2046·2019-08-30 15:43
閱讀 674·2019-08-29 15:25
閱讀 1061·2019-08-29 12:19
閱讀 1939·2019-08-23 18:32
閱讀 1522·2019-08-23 17:59
閱讀 951·2019-08-23 12:22