CSS line-height淺析(2)

来源:http://www.cnblogs.com/cc156676/archive/2016/07/15/5673410.html
-Advertisement-
Play Games

上一篇僅僅考慮了純文本的情況,現在,來探討一下圖像。 首先,請看如下代碼: 其效果圖是這樣的: 可以看到,圖像的下邊緣依然有一些背景顏色,極其影響頁面的美觀,那麼,這些紅色背景是怎麼來的呢? 如果我們改變line-height的值,會發現圖像下邊緣的紅色背景區域也會跟著變化,比如將line-heig ...


上一篇僅僅考慮了純文本的情況,現在,來探討一下圖像。

首先,請看如下代碼:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3     <head>
 4         <style>
 5         div {
 6             background-color: red;
 7             line-height: normal;
 8         }
 9         </style>
10     </head>
11     <body>
12         <div>
13             <img src="1.jpg" src="A picture" style="width:178px;height:100px">
14         </div>
15     </body>
16 </html>

其效果圖是這樣的:

可以看到,圖像的下邊緣依然有一些背景顏色,極其影響頁面的美觀,那麼,這些紅色背景是怎麼來的呢?

如果我們改變line-height的值,會發現圖像下邊緣的紅色背景區域也會跟著變化,比如將line-height值設置為50px,其效果圖為:

那麼,是什麼原因導致了這一變化呢?

為了說明得更清楚,我們向頁面中添加另外一些輔助性的東西;代碼如下:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3     <head>
 4         <style>
 5         div {
 6             font-size: 16px;
 7             background-color: red;
 8             line-height:50px;
 9         }
10         span {
11             display: inline-block;
12             background-color: green;
13         }
14         </style>
15     </head>
16     <body>
17         <div>
18             <img src="1.jpg" src="A picture" style="width:178px;height:100px">
19             <span>Something xxx</span>
20         </div>
21     </body>
22 </html>

其頁面效果為:

如果我們改變字體大小,比如將font-size值設置為32px;其頁面效果為:

通過上一篇文章的分析,我們知道,line-height決定了行內元素的高度,所以在我們只改變font-size而沒有改變line-height的情況下,綠色背景的文本高度並沒有變化。

由於font-size增加了,所以內容區的高度增加了。

圖像的下邊緣沒變,(vertical-align的預設值為baseline),文本的基線也就不變。

然而,文本內容區增大了,在行內框高度不變的前提下,只能行間距減小,於是整個盒子都表現得向上移動。

右邊文本元素下邊占的地方少了,左邊圖像下邊的紅色背景區域也相應減少了。

然後我們刪掉輔助的<span>元素,保留所有CSS設置,會發現圖像紋絲不動,如下圖:

也就是說,在圖像右邊有文本的時候,圖像與其基線對齊;即使圖像右邊沒有文本,圖像也與一個假想的文本的基線對齊;由此,引出了一個“隱藏文本節點”的概念。

(註:此概念來自張鑫旭大神,如需瞭解原作者的觀點,請移步他的個人博客,本文觀點只代表我個人理解。)

vertical-align:baseline,要求一個元素的基線與其父元素的基線對齊;

如果一個元素沒有基線,比如圖像或者表單輸入元素或者其它替換元素,則是元素的底端與父元素的基線對齊。

然而,如果父元素是一個空的div,如何確定父元素的基線?

這時,我們就可以假設,其實父元素中有一個隱藏的文本節點,只是我們看不見,它在暗中確定了父元素的基線。

這就是我對於“隱藏文本節點”的理解。

通過前面的分析,可以得知,圖像下邊緣多出來的一部分紅色背景區域,實際上是隱藏文本節點在作怪;

更準確地說,是因為隱藏文本節點的line-height以及vertical-align:baseline在作怪

知道了原因,我們就能對症下藥地解決問題,以下是三種去除那些紅色背景的方法。

方法一:由於vertical-align只能作用於行內元素和替換元素(如圖像和表單輸入元素),只要將圖像塊狀化,就能解決問題。代碼如下:

1 img {
2     display:block;
3 }

方法二:由於vertical-align的預設值為baseline,圖像的下邊緣與那些隱藏文本的基線對齊,才會多出來一些紅色背景;如果改變vertical-align的值,將其設置為bottom(底線對齊),就能解決問題。代碼如下:

1 img {
2     vertical-align: bottom;
3 }

方法三:設置line-height的值足夠小,讓隱藏文本的基線上移。代碼如下:

1 div {
2     line-height: 0;
3 }

當line-height的值為0時,這個元素的行內框的高度就是0;它該有的四條線都重合在了一起,位於文本的中間,也就是基線上移了。

(當line-height為0時,邊框是一條直線,可以簡單地把邊框的那一條直線看成重合的線,比較形象。)

上面三種方法的頁面效果一致,實踐中可根據需要使用。

 


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

-Advertisement-
Play Games
更多相關文章
  • × 目錄 [1]原始值 [2]對象 [3]顯式[4]隱式 前面的話 所有程式設計語言的重要特征是具有進行類型轉換的能力,javascript給開發者提供了大量簡單的類型轉換方法。javascript是一門弱類型語言,所以類型轉換成為其比較複雜的一部分。本文將從原始值轉換成原始值、對象轉換成原始值、顯 ...
  • 1.本次用到錯誤提示文字的顏色 http://v3.bootcss.com/css/#forms jquery 教程: http://www.w3school.com.cn/jquery/index.asp 2.工程地址:https://github.com/digitalClass/web_pag ...
  • 這一部分我們來簡單應用一下line-height屬性。 一、單行文本垂直居中 代碼如下: 頁面效果: 二、圖像水平垂直居中 代碼如下: 頁面效果: 其實現原理,我們可以有兩種方式解讀。 第一種方式,先讓隱藏文本節點垂直居中,然後圖像與它垂直居中對齊。 來看這段代碼: 其頁面效果為: 前面我們提到過, ...
  • js程式是構建在事件之上的。輸入可能來自不同的外部源。在一些語言中,我們習慣地編寫代碼來等待某個特定的輸入。var text=downloadSync('http://example.com/file.txt'); console.log(text); 像這樣的形式downloadSync稱為同步函... ...
  • CSS(Cascading Style Sheet,層疊樣式表),及其精巧且富有表達力,開發者可以用最為高效的方式高度掌控網頁內容的表示。 1. 盒模型 CSS中的一個基本概念是盒模型(box model)。可見元素會在頁面中占據一個矩形區域,該區域會在頁面中占據一個矩形區域,該區域就是元素的盒子, ...
  • × 目錄 [1]條件語句 [2]迴圈語句 [3]跳轉語句 前面的話 預設情況下,javascript解釋器依照語句的編寫順序依次執行。而javascript中的很多語句可以改變語句的預設執行順序。本文介紹可以改變語句預設執行順序的條件語句、迴圈語句和跳轉語句 條件語句 腳本的威力體現在它們可以根據人 ...
  • 開發者工具 現在一般的瀏覽器都內置了開發者工具,快捷鍵F12可以打開,如Chrome瀏覽器下,Sources面板下找到對應的js文件 這是首選方法,但是對於SPA程式(比如easyui),可能找不到內嵌頁面。所以如果是SPA程式,可能要想其它方法。 vs下在js代碼處斷點 這種方法對於SPA內嵌頁面... ...
  • ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...