深入理解line-height與vertical-align

来源:http://www.cnblogs.com/xiaohuochai/archive/2016/03/13/5271217.html
-Advertisement-
Play Games

[1]line-height [2]vertical-align [3]應用


×
目錄
[1]行高 [2]垂直對齊 [3]應用

前面的話

  line-height、font-size、vertical-align是設置行內元素佈局的關鍵屬性。這三個屬性是相互依賴的關係,改變行間距離、設置垂直對齊等都需要它們的通力合作。在CSS字體裡面已經詳細介紹了font-size的相關內容,本文將主要介紹line-height與vertical-align。本文涉及到的術語解釋參考塊級元素基本術語行內元素基本術語

 

line-height

定義

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

  值: <length> | <percentage> | <number> | normal | inherit

  初始值: normal

  應用於: 所有元素

  繼承性: 有

  百分數: 相對於元素的字體大小font-size

術語

  要深入理解line-height,需要理解關於行框構建的常用術語。

內容區

  對於行內非替換元素或匿名文本某一部分,font-size和font-family確定了內容區的高度。在宋體情況下,如果一個行內元素的font-size為15px,則內容區的高度為15px;而在其他字體情況下,內容區的高度並不等於字體大小

行內框

  內容區加上行間距等於行內框。如果一個行內非替換元素的font-size為15px,line-height為21px,則相差6px。用戶代理將這6像素一分為二,將其一半分別應用到內容區的頂部和底部,這就得到了行內框

 

  當line-height小於font-size時,行內框實際上小於內容區

 

行框

  行框定義為行中最高行內框的頂端到最低行內框底端之間的距離,而且各行框的頂端挨著上一行行框的底端

框屬性

  內邊距、外邊距和邊框不影響行框的高度,即不影響行高

  行內元素的邊框邊界由font-size而不是line-height控制

  外邊距不會應用到行內非替換元素的頂端和底端

  margin-left、padding-left、border-left應用到元素的開始處;而margin-right、padding-right、border-right應用到元素的結尾處

 

替換元素

  行內替換元素需要使用line-height值,從而在垂直對齊時能正確地定位元素。因為vertical-align的百分數值是相對於元素的line-height來計算的。對於垂直對齊來說,圖像本身的高度無關緊要,關鍵是line-height的值

  預設地,行內替換元素位於基線上。如果向替換元素增加下內邊距、外邊距或邊框,內容區會上移。替換元素的基線是正常流中最後一個行框的基線。除非,該替換元素內容為空或者本身的overflow屬性值不是visible,這種情況下基線是margin底邊緣

 

vertical-align

定義

  vertical-align用來設置垂直對齊方式,所有垂直對齊的元素都會影響行高

  值: baseline | sub | super | top | text-top | middle | bottom | text-bottom | <length> | <percentage> | inherit

  初始值: baseline

  應用於: 行內元素、替換元素、表單元格

  繼承性: 無

  百分數: 相對於元素的行高line-height

  [註意]IE7-瀏覽器中vertical-align的百分比值不支持小數行高,且取baseline、middle、text-bottom等值時與標準瀏覽器在展示效果不一樣,常用的解決辦法是將行內元素設置display:inline-block 

vertical-align:baseline(元素的基線與父元素的基線對齊)
vertical-align:sub(降低元素的基線到父元素合適的下標位置)
vertical-align:super(升高元素的基線到父元素合適的上標位置)
vertical-align:bottom(把對齊的子元素的底端與行框底端對齊)
vertical-align:text-bottom(把元素的底端與父元素內容區域的底端對齊)
vertical-align:top(把對齊的子元素的頂端與行框頂端對齊)
vertical-align:text-top(把元素的頂端與父元素內容區域的頂端對齊)
vertical-align:middle(元素的中垂點與父元素的基線加1/2父元素中字母X的高度對齊)
vertical-align:(+-n)px(元素相對於基線上下偏移npx)
vertical-align:x%(相對於元素的line-height值)
vertical-align:inherit(從父元素繼承vertical-align屬性的值)

  [註意]<sub>和<sup>預設攜帶樣式vertical-align:sub/super

inline-block底部空隙

  inline-block元素在塊級元素中留空隙就是因為圖像的預設垂直對齊方式是基線對齊(基線對齊在原理上圖像底邊與匿名文本大寫英文字母X的底邊對齊);而匿名文本是有行高的,所以X的底邊距離行框有一段距離,這段距離就是圖像留出的空隙

  於是,解決這個問題有以下幾個解決辦法

  [1]display:block

  因為垂直對齊方式只能作用於替換元素和行內元素,更改為塊級元素,會使垂直對齊方式失效

  [2]父級的line-height: 0

  這樣使匿名文本與行框的距離為0

  [3]vertical-align: top/middle/bottom

 

應用

【1】單行文本水平垂直居中

div{
    line-height: 100px;
    width: 100px;
    text-align: center;
    border: 1px solid black;
}
<div>測試文字</div>

  [註意]好多地方都寫著單行文本垂直居中是將高度和行高設置成一樣的值,但高度其實是沒有必要設置的。僅僅設置行高就可以,文字在一行中本身就是垂直居中顯示掃

【2】圖片近似垂直居中

div{
    line-height: 200px;
    text-align: center;
}
img{
    vertical-align: middle;
}
<div>
    <img src="#" alt="#">
</div>

  由於字元X在em框中並不是垂直居中的,且各個字體的字元X的高低位置不一致。所以,當字體大小較大時,這種差異就更明顯

  [註意]IE7瀏覽器在寫塊級元素包含行內元素時一定要寫成換行寫法,而不要寫在一行

//正確1
<div>
    <img src="#" alt="#">
</div>
//正確2
<div><img src="#" alt="#"><!-- 這裡要折行或空格 -->
</div>
//錯誤
<div><img src="#" alt="#"></div>

【3】圖片完全垂直居中

  在方法2的基礎上設置塊級元素的font-size為0,則可以設置圖片完全垂直居中

div{
    line-height: 200px;
    text-align: center;
    font-size: 0;
}
img{
    vertical-align: middle;
}
<div>
    <img src="#" alt="#">
</div>

【4】多行文本水平垂直居中

  由於方法3設置font-size為0的局限性,塊級元素裡面無法放置文本。方法4主要通過新增元素來實現垂直居中效果,該方法也可用於圖片的水平垂直居中

div{
    height: 100px;
    width: 200px;
    background-color: pink;
    text-align: center;
}
span{
    display:inline-block;
    vertical-align: middle;
    line-height: 20px;
    width: 100px;
}    
i{
    display: inline-block;
    height: 100%;
    vertical-align: middle;
}
    <div>
        <i></i><span>我是特別長的特別長的特別長的特別長的多行文字</span>
    </div>    

【5】圖標和文本對齊

<方法一>使用長度負值

img{
    vertical-align: -5px;
}

  根據實踐經驗,20*20像素的圖標後面跟14px的文字,vertical-align設置為-5px可以達到比較好的對齊效果

<方法二>使用文本底部對齊

img{
    vertical-align: text-bottom;
}

  使用baseline會使圖標偏上;使用top/bottom會受到其他行內元素影響造成定位偏差;使用middle需要恰好的字體大小且相容性不高;使用text-bottom較合適,不受行高及其他內聯元素影響


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 簡單js JavaScript 是一個鬆散性的語言 對象屬性卻不想c中的結構體或者c++ 和java的對象, 對象繼承機制 使用原型的prototype(原型鏈),js的分為三部分ECMAScript 、文檔DOM對象、瀏覽器BOM對象 1. 核心(ECMAScript) (語法、類型、語句、關鍵字
  • Chapter4 變數、作用域和記憶體問題 l  理解基本類型和引用類型的值 l  理解執行環境 l  理解垃圾收集   4.1基本類型和引用類型的值 l  ECMAScript變數包含兩種不同數據類型的值:基本類型值和引用類型值。 l  在將一個值賦給變數時,解析器必須確定這個值是基本類型值還是引用
  •   第一節 搭建開發環境 第二節 顯示頁面標題 第三節 實現頁面佈局      React Native,是顛覆性的移動開發技術。它使用js開發,又是原生應用,不同於Hybrid. 簡單的理解:它提供一個原生項目,然後規定js與原生項目的介面,編譯原生項目,打包程式員編寫的js, 共同形成一個完整的
  • 單擊,顯示警告框。onclick特性的值不能使用未經轉移的HTML語法字元:&,",<,>。若想使用雙引號: 通過event變數,可以直接訪問事件對象,且,在函數內部,this值等於事件的目標元素,例: 還可以使用擴展作用域,在函數內部可以像訪問局部對象一樣訪問document及該元素本身,so可以
  • 第一次玩codewars,選了個最簡單的題目 要求是: You have to write a function that describe Leo: if oscar was (integer) 88, you have to return "Leo finally won the oscar!
  • 在西方國家羅馬字母陣營中,字體分為兩大種類:Sans Serif和Serif,打字機體雖然也屬於Sans Serif,但由於是等寬字體,所以另外獨立出Monospace這一種類,例如在Web中,表示代碼時常常要使用等寬字體。  Serif的意思是,在字的筆劃開始及結束的地方有額外的裝飾,而且筆劃的粗
  • 由於在工作中需要使用AJAX請求其他功能變數名稱下的請求,但是會出現拒絕訪問的情況,這是因為基於安全的考慮,AJAX只能訪問本地的資源,而不能跨域訪問。 比如說你的網站功能變數名稱是aaa.com,想要通過AJAX請求bbb.com功能變數名稱中的內容,瀏覽器就會認為是不安全的,所以拒絕訪問。 會出現跨域問題的幾種情況:
  • 我不喜歡一開始就去討論某某有多強大,因為我覺得那樣沒意思,首先我們的知道它是乾什麼,對我們有啥用,再去討論它的強大之處也不遲。那和往常一樣我們先來看幾個例子。 又比如我們想提取var str = 'eignwererherhtml5ewrqrpasfnh' ;這段文本裡面的html5,又應該怎麼做,
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...