深入解析vertical-align line-height屬性

1.vertical-align

默認值:baseline 即設置該屬性的元素的基線(baseline)與行框的基線對齊。W3C上描述的是與父級元素的基線對齊是不準確的,比如出現多行的情況。
生效的對象 : 只對inline,inline-block的元素有效,對塊級元素無效。
繼承性:無繼承性
常用的值:
baseline :元素的基線與行框的基線對齊。
middle : 元素所在行內框的中線與行框的中線對齊。
top : 元素所在行內框的頂邊與行框內高度最大的行內框頂部對齊
bottom : 元素所在行內框的底邊與行框內高度最大的行內框底部對齊
固定值 : 元素的基線相對行框基線向上(為正值時)或向下((為負值時)偏移指定距離。
text-top :元素頂部與行框內的匿名文本的頂部對齊。
text-bottom :元素底部與行框內的匿名文本的底部對齊。
行內元素在布局時,首先也是最重要的是確定行框的基線位置

2.line-height

line-height行高是指文本行基線之間的距離。行高line-height實際上只影響行內元素和其他行內內容,而不會直接影響塊級元素,也可以為一個塊級元素設置line-height,但這個值只是應用到塊級元素的內聯內容時才會有影響。在應用到塊級元素時,line-height定義了元素文本基線之間的最小距離,即最小行高

line-height不會對inline-block的元素直接起作用,但可能會作用在inline-block的子元素上,這樣間接改變inline-block高度
默認值:normal(大概是font-size的1.3倍)
應用于:所有元素
可繼承
常用值:
固定值 : 會被子元素繼承這個定值
normal :相當于數字1.3
百分數:相對于元素的font-size計算(font-size可繼承)。這個值會被子元素繼承下去(計算出來的定值)。
數字 :相對于元素的font-size計算,但是子元素只會繼承這個數字,然后根據自己的font-size計算各自的line-height

3.替換元素和非替換元素

替換:img input button textarea 自定義的inline-block
非替換 : i,a,span等

4.各種行內元素的基線與中線位置

Input框
基線位置 輸入的字母x的底部,
middle線 位置, 包含margin之后這個行內框高度的中間。middle對齊時就是middle線與行框的x的中心對齊

Textarea ,img
基線位置 元素底部(含margin框哦) middle線位置 包含margin之后這個行內框高度的中間。

Button按鈕
基線位置 里面字母x的底部,middle線位置,包含margin之后該行內框高度的中間 。

自定義inline-block
只有一行的inline-block 如果加上了overflow屬性,其表現和 textarea img是一樣(我也不知道原理是啥,input框基線位置不會受overflow影響) ,基線為包含margin之后該行內框高度的底部 。不加的話 基線位置 在里面字母x的底部
overflow只影響inline block的基線位置,middle線位置不管怎樣都是 包含margin之后該行內框高度的中間

對于里面有多行的inline-block
沒有overflow屬性的情況下,基線位置 這個inline-block里最后一行(如果只有一行,那這行就是最后一行)的行框里面的x的底部 ,不管這個inline block是否定高,內容是否溢出, 也就是說就算里面的內容超出了block的邊界,基線位置還是最后一行的x的底部。
設置了overflow屬性之后,基線位置和單行時的情況是一樣的。
middle線的位置為包含margin之后該行內框高度的中間 。

Inline元素
這里我把由display為inline的標簽包裹的字體形成的盒子,稱為字體盒子(自己起的名字),像這種<span>xxx<span> ,在chrome中檢查元素,包裹字體的藍色塊就是個字體盒子。字體盒子的高度只和font-size有關,默認大概為font-size的1.3倍,在span里面改變line-height,字體盒子的高度不會變化,但是注意雖然字體盒子的高度沒變,但是字體盒子所在的inline box的高度是變了的(line-height改變的),我們用眼睛看不到這個高度的。字體盒子的高度的中間線和該inline box的高度中間線是重合的,也就是說字體盒子是在inline box的中間的,并不是文字在中間,因為字體盒子的中間并不是文字的中間 。像這種inline元素的基線位置在字母x的底部,middle線在這個inline box高度的中間,也是這個字體盒子的中間(不是字體的中間),因為無論line-height比字體盒子高度大還是小,它的中間線和字體盒子的中間線都是重合的。

在進行行內元素布局時,每個inline box會根據自己的vertical-align去找參照物對齊。然后計算最高的inline box的頂部和最低的inline box的底部間的距離,這就是這行的高度了。

行框的middle就是確定基線的那個x的中線(過中心交點的平行線)
關于這些只在chrome上試過,其他瀏覽器規則是否一樣有待試驗。

用來測試的代碼

<!DOCTYPE html>
<html>
<head>
    <title>demo4</title>
    <style type="text/css">
        input {
            width: 150px;
            height: 80px;
        }
        textarea {
            width: 200px;
            height: 100px;
        }
        div{
            background-color: #ccc;
        }
        input {
                    font-size: 30px;
                    width: 150px;
                    height: 80px;
                     vertical-align: middle;
                    /* margin-bottom: 17px; */
                overflow: hidden;
                }
      textarea {
            width: 150px;
            height: 134px;
            }
    </style>
</head>
<body>
    <div style="
    /* line-height: 100px; */
">xX
<input type="text" name="" placeholder="input">
<textarea style="
    vertical-align: middle;
">textarea</textarea>
    <button style="
    vertical-align: middle;
    margin-bottom: 0px;
    height: 100px;
">x</button>  x
    <span style="
    display: inline-block;
    vertical-align: baseline;
    height: 30px;
    /* width: 20px; */
    /* overflow: hidden; */
    margin-bottom: 10px;
">x<br>x</span>
    <span style="
    /* overflow: hidden; */
    /* font-size: 30px; */
    line-height: 6px;
    vertical-align: middle;
    /* margin-bottom: 10px; */
">xx<span></span></span></div>
</body>
</html>

感謝:
深入了解css的行高Line Height屬性
深入理解line-height與vertical-align
我對CSS vertical-align的一些理解與認識(一)
CSS深入理解vertical-align和line-height的基友關系

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,106評論 6 542
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,441評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,211評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,736評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,475評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,834評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,829評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,009評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,559評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,306評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,516評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,038評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,728評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,132評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,443評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,249評論 3 399
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,484評論 2 379

推薦閱讀更多精彩內容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,780評論 1 92
  • 參考文章:深入了解CSS的line-height屬性Vertical-Align: 你需要知道的所有事【譯】Ver...
    若邪Y閱讀 3,480評論 1 6
  • 以下文章是我在網上收集的內容,為了記錄自己的學習以及為了以后不到處找而記錄下來,如果對你有用,請感謝寫這些文章的前...
    DCbryant閱讀 949評論 0 2
  • 有些東西我們經常用,但是我們卻并不了解它的原理,所以一旦換了場景,好多東西就不知道該怎么用了。最近一直很糾結ver...
    朱小維閱讀 4,981評論 8 34
  • 1,行高的定義 行高是指行間的距離,也就是基線之間的距離,而只有兩行文字才會存在兩個基線,那么為什么單行文字還具有...
    Bennt閱讀 1,665評論 2 7