首頁 web前端 html教學 (译)关于Vertical-Align:你所需要知道的_html/css_WEB-ITnose

(译)关于Vertical-Align:你所需要知道的_html/css_WEB-ITnose

Jun 24, 2016 am 11:42 AM

很多时候,我总是需要垂直对齐一行元素。之前,我一般用float,有时用position: absolute,实在没办法就只有设置margin或padding。

我真的不喜欢上面那些方法。float只能让一行元素在顶部对齐,如果要垂直对齐则需要另外调整。position: absolute让元素脱离文档流,使得它们不能影响周围的元素。而设置margin或padding让css变得不优雅。

但是vertical-align让我眼前一亮,我觉得它应该得到更多的关注。从技术上讲,使用vertical-align布局是hack行为,因为它并不是为了解决这个问题而诞生的。它本来是被用来对齐文本和元素旁边的文本。尽管如此,vertical-align可以让我们在不同的上下文环境灵活的,细粒度的对齐元素,因为不需要知道元素的大小,所有元素仍然在文档流中。

使用Vertical-Align的条件

vertical-align是用来对齐行内元素的,也就是说作用于这些display属性inline,inline-block,inline-table(本文不讨论)。

inline-block顾名思义,块级元素在行内元素里面,元素可以有width,height,border, margin,padding.

另一方面,行内元素会一个接一个排在一起,只要在当前行还有空间容纳行内元素。如果没有空间则在下面创建新的一行。这些行内元素被称作line box。

line box包含一行的所有内容,一行内的元素的大小会影响line box的高度。下面的图显示了line box的顶部和底部是怎样定义的,两个红线间表示一个line box.

基线(baseline)和外边缘(Outer Edges)

垂直对齐最重要的参考点line box涉及元素的基线,在某些情况下,元素盒子模型的顶部边缘和底部边缘是非常重要的。下图让我们直观的看到涉及元素的baseline和outer edges

红线表示行高(line-height)的顶部和底部边缘,绿线表示文字的高度(font-size),蓝线是基线。

上面左边的图line-height等于font-size,所以红线和绿线重合。中间图line-height是font-size的两倍,右边图的line-height是font-size的1/2.

行内元素的外边缘会和line-height的顶部和底部边缘对齐,上面右图中,行内元素的外边缘仍然是红线,尽管line-height比font高度小。

另外,可以看到行内元素的基线在font高度一半位置偏下。

inline-block元素

从左到右,inline-block元素里面有in-flow(没有脱离文档流)内容,inline-block元素里面有in-flow内容但overflow:hidden,inline-block元素里面有out-flow内容(内容区域有高度)。

红线表示margin的边缘,黄线是border,绿线是padding,内容是蓝色区域,蓝线是baseline.

inline-block元素的外边缘是它的margin-box的顶部和底部边缘。

可以看到,inline-block元素的baseline取决于元素是否有in-flow内容。

上面左图的baseline是上一个内容元素的baseline,这个内容元素根据自身情况确定自己的baseline.

中图设置overflow属性为非visible,这时baseline是inline-block元素的margin-box的底部边缘,也就是它自己的底部边缘。

右图的baseline仍然是它的margin-box的底部边缘。

Line Box

 

<span class="center">    <span class="middle bg-grey">This</span>    <span class="tall box bg-grey text-top"> </span>    <span class="top bg-grey">can</span>    <span class="tall box bg-grey text-bottom"> </span>    <span class="bottom bg-grey">happen.</span></span>
登入後複製

.text .middle {  display: inline-block;  vertical-align: middle;}.text figure .box {  min-width: 1em;  min-height: 1em;}.text .text-top {  display: inline-block;  vertical-align: text-top;}.text .top {  display: inline-block;  vertical-align: top;}.text .text-bottom {  display: inline-block;  vertical-align: text-bottom;}.text figure .box.tall {  height: 2em;}.text .bottom {  display: inline-block;  vertical-align: bottom;}
登入後複製

从上面可以清楚的看到vertical的几个属性值的区别。

注意CSS 2.1 does not define the position of the line box's baseline.? the W3C Specs

line box的baseline是不可见的,不过可以在行的开始添加一个字符,就像上图的字符x,如果这个字符没有以任何一种方式对齐,那么这个字符就默认在baseline上。

Vertical-Align的属性值

橘色线表示line box的baseline.可以看到,inline-block元素垂直方向的中线(baseline)划过line box的baseline再加上一半垂直方向的font高度的位置。

text-top和text-bottom

原文的图不好,本?简单的搞了个

<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>Insert title here</title><style type="text/css">*{    margin: 0;    padding: 0;}div{    font-size: 12px;    line-height: 100px;    border:1px solid blue;}span{    line-height: 16px;    padding:5px;    display: inline-block;    border: 1px solid red;}#a{    vertical-align:text-top;}#b{    vertical-align:text-bottom;}</style></head><body><div>    <span id='a'>text-top</span>xxx<span id='b'>text-bottom</span></div></body></html>
登入後複製

最外边蓝线是xxx的line-height外边缘,可以看到它们针对的font(不是line-height)的上下边缘.

top和bottom

这次针对的是line-height上下边缘了。

Why Vertical-Align Behaves The Way It Behaves

现在我们可以看看vertical-align在一些特定情景下的应用,尤其是可能会出错的情景。

让图标垂直居中

对上面添加点辅助线

 

Movement Of the Line Box’s Baseline

这是一个常见的陷阱,line box的baseline受一行的所有元素影响,而大多数vertical-align属性(top,bottom除外),都受这个baseline影响。

如果一行内有一个占满整个高度(line box的line-height上下边缘)的元素,高的元素的vertical-align这时不会起作用,因为没有空间再让它调整以适应line box的baseline,这时整行的baseline是矮元素的baseline.

 

如果您觉得本文的内容对您有所帮助,您可以打赏我: 

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
了解HTML,CSS和JavaScript:初學者指南 了解HTML,CSS和JavaScript:初學者指南 Apr 12, 2025 am 12:02 AM

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML:結構,CSS:樣式,JavaScript:行為 HTML:結構,CSS:樣式,JavaScript:行為 Apr 18, 2025 am 12:09 AM

HTML、CSS和JavaScript在Web開發中的作用分別是:1.HTML定義網頁結構,2.CSS控製網頁樣式,3.JavaScript添加動態行為。它們共同構建了現代網站的框架、美觀和交互性。

HTML,CSS和JavaScript的未來:網絡開發趨勢 HTML,CSS和JavaScript的未來:網絡開發趨勢 Apr 19, 2025 am 12:02 AM

HTML的未來趨勢是語義化和Web組件,CSS的未來趨勢是CSS-in-JS和CSSHoudini,JavaScript的未來趨勢是WebAssembly和Serverless。 1.HTML的語義化提高可訪問性和SEO效果,Web組件提升開發效率但需注意瀏覽器兼容性。 2.CSS-in-JS增強樣式管理靈活性但可能增大文件體積,CSSHoudini允許直接操作CSS渲染。 3.WebAssembly優化瀏覽器應用性能但學習曲線陡,Serverless簡化開發但需優化冷啟動問題。

HTML的未來:網絡設計的發展和趨勢 HTML的未來:網絡設計的發展和趨勢 Apr 17, 2025 am 12:12 AM

HTML的未來充滿了無限可能。 1)新功能和標準將包括更多的語義化標籤和WebComponents的普及。 2)網頁設計趨勢將繼續向響應式和無障礙設計發展。 3)性能優化將通過響應式圖片加載和延遲加載技術提升用戶體驗。

HTML與CSS vs. JavaScript:比較概述 HTML與CSS vs. JavaScript:比較概述 Apr 16, 2025 am 12:04 AM

HTML、CSS和JavaScript在網頁開發中的角色分別是:HTML負責內容結構,CSS負責樣式,JavaScript負責動態行為。 1.HTML通過標籤定義網頁結構和內容,確保語義化。 2.CSS通過選擇器和屬性控製網頁樣式,使其美觀易讀。 3.JavaScript通過腳本控製網頁行為,實現動態和交互功能。

HTML:建立網頁的結構 HTML:建立網頁的結構 Apr 14, 2025 am 12:14 AM

HTML是構建網頁結構的基石。 1.HTML定義內容結構和語義,使用、、等標籤。 2.提供語義化標記,如、、等,提升SEO效果。 3.通過標籤實現用戶交互,需注意表單驗證。 4.使用、等高級元素結合JavaScript實現動態效果。 5.常見錯誤包括標籤未閉合和屬性值未加引號,需使用驗證工具。 6.優化策略包括減少HTTP請求、壓縮HTML、使用語義化標籤等。

HTML的角色:構建Web內容 HTML的角色:構建Web內容 Apr 11, 2025 am 12:12 AM

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。

HTML:是編程語言還是其他? HTML:是編程語言還是其他? Apr 15, 2025 am 12:13 AM

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增強WebevebDevelopment。

See all articles