深刻理解css之vertical-align

前言

vertical-align用來指定行內元素(inline)或表格單元格(table-cell)元素的垂直對齊方式。也就是說,對於塊級元素,vertical-align是不起做用的。css

vertical-align的各種屬性值

vertical-align的屬性值能夠歸爲如下4類:html

  • 線類,如 baseline、top、middle、bottom;
  • 文本類,如 text-top、text-bottom;
  • 上標下標類,如 sub、super;
  • 數值百分比類,如 10px、1em、5%;

線類

baseline,baseline爲vertical-align的默認值,其意思是指基線對齊,所謂基線,指的是字母x的下邊緣,具體可看前文深刻理解css之line-height有講解到,不懂的小夥伴建議先看看這篇文章。咱們來看個例子,代碼以下:segmentfault

.box {
    width: 100px;
    line-height: 100px;
    border: 1px solid #ccc;
}
<div class="box">
    <span class="text">文本</span>
</div>

效果以下:字體

圖片描述

因爲baseline是默認值,因此能夠不用寫。.box的line-height爲100px,這實際上是給「strut」設置的(不懂strut概念的能夠看看前面的文章深刻理解css盒子模型,簡單點說就是每個行框盒子都有一個看不見的節點,該節點繼承了line-height),所以.text對齊於該節點的基線(能夠想象成這個看不見的節點有一個字母x,而.text就是跟這個字母x的下邊緣對齊)spa

關於baseline,有一個須要注意的地方就是inline-block元素,若是一個inline-block元素,裏面沒有內聯元素,或者overflow不是visible,則該元素的基線是其margin底邊緣;不然其基線就是元素裏面最後一行內聯元素的基線。例子以下:code

.text {
    display: inline-block;
    width: 100px;
    height: 100px;
    border: 1px solid #ccc;
}
<div class="container">
    <span class="text">文本</span>
    <span class="text"></span>
</div>

效果以下:orm

圖片描述

top,對於內聯元素,指的是元素的頂部和當前行框盒子的頂部對齊;對於table-cell元素,指的是元素的頂padding邊緣和表格行的頂部對齊。例子以下:htm

.box {
    width: 100px;
    line-height: 100px;
    border: 1px solid #ccc;
}
.top {
    line-height: normal;
    vertical-align: top;
}
<div class="box">
    <span class="top">文本</span>
</div>

效果以下:blog

圖片描述

bottom,跟top相似,將頂部換成底部便可。繼承

middle,這個屬性值用得比較多。對於內聯元素指的是元素的垂直中心點與行框盒子基線往上1/2x-height處對齊,簡單點說就是字母x的中心位置對齊;對於table-cell元素,指的是單元格填充盒子相對於外面的表格行居中對齊。基本上全部字體中,字母x的位置都是偏下一點的,font-size越大偏移越明顯,所以,字母x中心的位置不是行框盒子的中心,也就是說vertical-align只能實現近似垂直居中對齊。

文本類

text-top,指的是盒子的頂部和父級內容區域的頂部對齊。

text-bottom,指的是盒子的底部和父級內容區域的底部對齊。

例子以下:

.box {
    width: 300px;
    line-height: 100px;
    border: 1px solid #ccc;
    font-size: 20px;
}
.f12 {
    font-size: 12px;
}
.f16 {
    font-size: 16px;
}
.f20 {
    font-size: 20px;
}
.text-top {
    line-height: normal;
    vertical-align: text-top;
    width: 100px;
}
<div class="box">
    <span class="f12">12px</span>
    <span class="f16">16px</span>
    <span class="f20">20px</span>
    <img class="text-top" src="./card.jpg"/>
</div>

效果以下:

圖片描述

所謂內容區域,能夠當作是鼠標選中文字後高亮的背景色區域,上面的例子中,因爲父元素設置的是20px,因此圖片的vertical-align設置text-top的時候,就能夠當作是跟子元素爲20px元素的內容區域頂部對齊。

上標下標類

上標和下標對應着兩個標籤super和sub,super在上面,sub在下面,這兩個屬性值在數學公式和化學表達式中用得比較多,平時咱們開發幾乎用不到,也沒啥好講的。

數值百分比類

vertical-align是支持數值的,而且兼容性也很是好,但大部分開發人員殊不知道vertical-align支持數值。對於數值,正值表示由基線往上偏移,負值表示由基線往下偏移。而百分比則是基於line-height來計算的,百分比用得比較少,由於line-height通常都是開發人員給出的,這時候數值就能夠精肯定位元素,不須要再使用百分比再去計算一遍。使用數值的代碼以下:

.box {
    width: 300px;
    line-height: 100px;
    border: 1px solid #ccc;
    font-size: 20px;
}
.num {
    line-height: normal;
    vertical-align: 20px;
}
<div class="box">
    <span class="num">文本</span>
</div>

效果以下:

圖片描述

vertical-align起做用的前提

vertical-align起做用是有前提條件的,這個前提條件就是:只能應用於內聯元素以及display值爲table-cell的元素。在css中,有些css屬性是會改變元素的display值的,例如float和position: absolute,一旦設置了這兩個屬性之一,元素的display值就是變爲block,所以,vertical-align也就失去了做用。下面這段代碼這樣寫就是錯的:

span {
        float: left;
        vertical-align: middle; /* 錯誤,該行代碼無效 */
   }

另外,更多人遇到的是如下這種無效的狀況:

.box {
    height: 200px;
}
.box > img {
    height: 100px;
    vertical-align: middle;
}
<div class="box">
    <img  src="1.jpg" />
</div>

其實,不是vertical-align無效,而是前面所說的「strut」的影響,因爲.box沒有設置line-height,因此「strut」的line-height就很是小,比圖片的高度小不少,vertical-align: middle無法發揮做用。這時給.box一個比較高的line-height,就會看到vertical-align起做用了:

.box {
    height: 200px;
    line-height: 200px;
}

vertical-align與line-height的關係

前面講了,vertical-align的百分比值是根據line-height來計算的。但實質上,只要是內聯元素,這兩個元素都會同時在起做用。以下例子:

.box {
    line-height: 32px;
}
.box > span {
    font-size: 24px;
}
<div class="box">
    <span>文本</span>
</div>

效果以下:

圖片描述

從代碼上看,好像.box的高度會是32px,但實質上.box的高度會比32px還要高。緣由是"strut"繼承了line-height: 32px,span也繼承了line-height: 32px,但二者的font-size不同,這就致使了"strut"的font-size比較小,而span的font-size比較大,也就是說它們的基線不在同一位置上,"strut"偏上一點,而span默認又是基線對齊,爲此,span整體會往上移以便跟"strut"基線對齊,.box元素就是這樣被撐高了。而解決方案能夠有如下幾種:

  • span元素不使用基線對齊,能夠改成top對齊
  • span元素塊狀化
  • line-height設置爲0
  • font-size設置爲0

總結

  • 講解了vertical-align的各種屬性值及其效果
  • vertical-align起做用的前提是內聯元素
  • vertical-align與line-height都是同時做用在內聯元素上的
相關文章
相關標籤/搜索