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
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...