CSS行高line-height的理解

来源:http://www.cnblogs.com/shouce/archive/2016/02/01/5174362.html
-Advertisement-
Play Games

一、行高的字面意思 “行高“顧名思義指一行文子的高度。具體來說是指兩行文子間基線間的距離。 基線是在英文字母中用到的一個概念,我們剛學英語的時候使用到的那個英語本子每行有4條線,其中底部第二條線就是基線,是a,c,z,x等字母的地邊線。 ————————頂線(top line)———————————


一、行高的字面意思

“行高“顧名思義指一行文子的高度。具體來說是指兩行文子間基線間的距離。

基線是在英文字母中用到的一個概念,我們剛學英語的時候使用到的那個英語本子每行有4條線,其中底部第二條線就是基線,是a,c,z,x等字母的地邊線。

 ————————頂線(top line)————————————————

——————————中線(middle line)————————————

————————————基線(base line)———————————

———————————————底線(bottom line)——————    


vertical-align中有top,middle,baseline,bottom與之是有關聯的,但是具體細節如何,瀏覽器差異怎樣,我還是不是很清楚。

但是由於中午跟英文長得不一樣,所以基線的說法就像老太太穿線一一對不上眼。你理解為底線之差也不為不可。只是定義一回事,表現則另一回事。

二、line-height與line boxes高度
先說一個大家熟知的現象,有一個空的div,<div></div>,如果沒有設置至少大於1像素高度height值時,該div的高度就是個0.如果該div裡面打入了一個空格或是一個漢字 ,則此div就會有一個高度。那麼您有沒有思考過,為什麼div裡面有文字後就會有高度呢?

這是個看上去很簡單的問題,是理解line-height非常重要的一個問題。可能有人會認為是:文子撐開的!文子占據空間,自然將div撐開。我一開始也是這樣理解的,但是事實上,深入理解inline模型後,我發現,根本不是文字撐開了div的高度,而是line-height!喲證明很簡單(如下測試代碼):

css代碼:



<!-- lang: css -->
 .test1{font-size:20px; line-height:0; border:1px solid #cccccc; backgroud:#eeeeee;}
<!-- lang: css -->
    .teset2{fon-size:0; line-height:20px; border:1px solid #cccccc; backgroud:#eeeeee;}

html代碼:

<!-- lang: html -->
<div class="test1">測試1</div>
<!-- lang: html -->
<div class="test2">測試2</div>

結果:test1 div有文字大小,但是行高為0,結果div的高度就是個0;test2 div文字大小為0,但是有行高,為20像素,結果div高度就是20像素。這就說明撐開div高度的是line-height不是文字內容。

到底這個line-height行高怎麼就產生了高度呢?在linline box模型中,有個line boxes,這個是看不見的。line boxes的工作就是包裹每行文字。一行文字一個 line boxes。例如”艾佛森退役"這5個字,如果它們在一行顯示,你艾佛森再牛,對不起,只有一個line boxes罩著你;但是”春哥純爺們“這5個字,要是豎著寫,一行一個,那真是夠爺們,一個字罩著一個line boxes,於是總計5個line boxes。line boxes什麼特性也沒有,就是高度。所以一個沒有設置height屬性的div的高度就是由一個line boxes的高度堆積而成的。

其實line boxes不是直接的生產者,屬於中層幹部,真正的活兒都是它的手下-inline boxes乾的,這些手下就是文字啦,圖片啦,span之類的inline屬性的標簽啦。line boxes只是個考察彙報人員,考察它的手下誰的實際line-height值最高,誰最高,它就要誰的值,然後向上彙報,形成高度。例如,<span style="line-height:20px;">取手下line-height<span style="line-height:40px;">最高</span>的值</span>.則line boxes的高度就是40像素了。

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

-Advertisement-
Play Games
更多相關文章
  • 參考老師的博客: 金角:http://www.cnblogs.com/alex3714/articles/5143440.html 銀角:http://www.cnblogs.com/wupeiqi/articles/4963027.html 一、常用函數說明: ★ lamba python lam
  • 一、什麼是裝飾模式 通過關聯機制給類增加行為,其行為的擴展由修飾對象來決定; 如JAVA IO流里的以下形式,BufferedReader為裝飾類,其關聯了一個具體對象(new FileReader(new File("test.txt"))),並對其進行裝飾,裝飾後擁有readLine行為(方法)
  • 2.15 max 2.15.1 語法: _.max(list, [iteratee], [context]) 2.15.2 說明: 返回list中的最小值。 list為集合,數組、對象、字元串或arguments iteratee作為返回最大值的依據 iteratee的參數(value, key,
  • 上一篇文章《聖杯佈局小結》總結了幾種常見的分欄佈局方法,這幾個方法都可以實現多欄頁面下,所有欄的高度可動態變化,某一欄寬度自適應的佈局效果,能滿足工作中大部分的佈局需求。後來我在搜集更多關於分欄佈局的文章時,發現了一個新的問題,這個問題在前面那篇文章中也有朋友在評論里跟我提起,就是如何在實現分欄佈局...
  • Geolocation(地理定位) 基本內容 地理定位 - 地球的經度和緯度的相交點 實現地理定位的方式 GPS - 美國的,依靠衛星定位 北斗定位 - 純國產,慣性定位技術和衛星定位 基站定位 - 移動運營商創建基站(提供信號源) 基於互聯網 - IP地址(PC端和移動端) 目前很多瀏覽器都具有定
  • 不到30行JS代碼實現的Excel表格,jQuery並非不可替代 某國外程式員展示了一個由原生JS寫成不依賴第三方庫的,Excel表格應用,有以下特性: 由不足30行的原生JavaScript代碼實現 不依賴第三方庫 Excel風格的語義分析 (公式以 "=" 開頭) 支持任意表達式 (=A1+B2
  • 0.前提 JavaScript對象的屬性分為兩種存在形態. 一種是存在實例中, 另一是存在原型對象中. 根據上述, 檢測屬性的時候會出現4種情況 既不存在實例中, 也不存在原型對象中 存在實例中, 不存在原型對象中 不存在實例中, 存在原型對象中 既存在實例中, 也存在原型對象中 1.hasOwnP
  • 層疊樣式表(CSS)的主要目的是給HTML元素添加樣式,然而,在一些案例中給文檔添加額外的元素是多餘的或是不可能的。事實上CSS中有一個特性允許我們添加額外元素而不擾亂文檔本身,這就是“偽元素”。 你一定聽說過這個詞,尤其是當你一直關註著我們的教程。點此瀏覽原作者的其他文章 事實上,的確有一些CSS
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...