首頁  >  文章  >  web前端  >  全面理解line-height與vertical-align_HTML/Xhtml_網頁製作

全面理解line-height與vertical-align_HTML/Xhtml_網頁製作

WBOY
WBOY原創
2016-05-16 16:45:581834瀏覽
前面的話

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

line-height

定義

  line-height行高是指文字行基線之間的距離。行高line-height其實只會影響行內元素和其他行內內容,而不會直接影響區塊級元素,也可以為一個區塊級元素設定line-height,但這個值只是應用到區塊級元素的內嵌內容時才會有影響。在區塊級元素上宣告line-height會為此區塊級元素的內容設定一個最小行框高度

  值: | | | 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 | | | inherit

  初始值: baseline

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

  繼承性: 無

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

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

CSS Code複製內容到剪貼簿
  1. vertical-align:baselinebaseline(元素的基線與父元素的基線對齊)
  2. vertical-align:sub(降低元素的基線到父元素適當的下標位置)   🎜>
  3. vertical-align:super(升高元素的基線到父元素適當的上標位置)
  4. vertical-align:bottombottom(🎜>bottom
  5. (🎜>(端與行框底端對齊)   
  6. vertical-align:text-bottom
  7. (父把元素的底端與父元素內容區域的底端端對齊)   
  8. vertical-align:top
  9. (對齊的子元素的頂端與行框頂端對準)  
  10. vertical-align:text-top
  11. (把元素的頂端對齊父元素內容區域的頂端對齊)   
  12. vertical-align:middle
  13. (元素的中垂點與父元素的基線加1/2父元素中字母X的高度對齊)   
  14. vertical-align
  15. :( -n)px(元素相對於基線上下偏移npx)   
  16. vertical-align:x%(相對於元素的line-height
  17. 值)   
  18. 值)    值)    值)    值)    值)   
  19. 值)   
值) 🎜>

vertical-align

:inherit(從父元素繼承vertical-align

屬性的值) 

  [注意]預設攜帶樣式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. 【1】單行文字水平垂直居中
  2. XML/HTML Code複製內容到剪貼簿
  3. div{   
  4.     line-height: 100px;   
  5.     width: 100px;   
  6.     text-align: center;   
  7.     border: 1px solid black;    }       div
>
測試文字div >  

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

【2】圖片近似垂直居中

XML/HTML Code複製內容到剪貼簿

  1. div{   
  2.     line-height: 200px;   
  3.     text-align: center;   
  4. }   
  5. img{   
  6.     vertical-align: middle;   
  7. }   
  8. div>  
  9.     img src="全面理解line-height與vertical-align_HTML/Xhtml_網頁製作" alt="全面理解line-height與vertical-align_HTML/Xhtml_網頁製作"> 🎜>>
  10.   div>  

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

  [注意]IE7瀏覽器在寫塊級元素包含行內元素時一定要寫成換行寫法,而不要寫在一行
複製代碼
代碼如下:
//正確1
全面理解line-height與vertical-align_HTML/Xhtml_網頁製作
//正確2
全面理解line-height與vertical-align_HTML/Xhtml_網頁製作
//錯誤
全面理解line-height與vertical-align_HTML/Xhtml_網頁製作

【3】圖片完全垂直居中

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

複製代碼複製代碼
複製代碼

複製代碼
程式碼如下:div{ line-height: 200px; text-align: center; font-size: 0;}img{ vertical-align: middle;}
複製程式碼程式碼如下:
全面理解line-height與vertical-align_HTML/Xhtml_網頁製作 【4】多行文字水平垂直居中   由於方法3設定font-size為0的局限性,因此在區塊級元素裡面無法放置文字。方法4主要透過新增元素來實現垂直居中效果,該方法也可用於圖片的水平垂直居中 XML/HTML Code複製內容到剪貼簿
  1. div{   
  2.     高度:100 像素;   
  3.     寬度:200 像素;   
  4.     背景顏色:粉紅色;   
  5.     文字對齊:居中;   
  6. }   
  7. 跨度{   
  8.     顯示:內聯塊;   
  9.     垂直對齊:中;   
  10.     高:20px;  
  11.     寬度:100 像素;   
  12. }       
  13. 我{   
  14.     顯示:內聯塊;   
  15.     高度:100%;   
  16.     垂直對齊:中;   
  17. }  

XML/HTML 程式碼將內容複製到剪貼簿
  1. div>  
  2.        >>span>我是特別長的特別長的特別長的特別長的多行文字跨度>  
  3.    div>    >
    

    

    


    
    
 

【5】圖示與文字對齊

使用長度負值

複製程式碼
程式碼如下:
全面理解line-height與vertical-align_HTML/Xhtml_網頁製作

根據實務經驗,20*20像素的圖示後面跟14px的文字,vertical-align設定為-5px可以達到比較好的視覺效果

使用文字底部對齊

複製程式碼程式碼如下:全面理解line-height與vertical-align_HTML/Xhtml_網頁製作 使用baseline使圖示偏上;使用top/bottom會受到其他行內元素影響造成定位偏差;使用middle需要正好的字體大小且相容性不高;使用text-bottom合適,不受行較高及其他內聯元素影響 以上就是本文的全部內容,希望對大家的學習有所幫助。 譯:http://www.cnblogs.com/xiaohuochai/p/5271217.html
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn