[转]CSS vertical-align属性详解 作者:黄映焜

2023-11-23 06:10

本文主要是介绍[转]CSS vertical-align属性详解 作者:黄映焜,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

posted @  2014-08-26 17:44 黄映焜
  • 前言:关于vertical-align属性.
  • 实践出真知.
  • 垂直居中.
  • 第二种用法.

前言:关于vertical-align属性

vertical-align属性可能是CSS属性中比较不好理解的一个。

W3C对它的解释是:该属性定义行内元素的基线相对于该元素所在行的基线的垂直对齐。

本文将通过一系列实例实验说明它的作用。

[注:将鼠标放置到本文的图片上可看到辅助线]

实践出真知

首先,在HTML body中定义一个用于实验的HTML结构

它包含一个div作为父元素,两张图片,和一个span元素,如下:

<div>Writing<img id="img1" src="img1.jpg" /> <span id="span">span元素</span> <img id="img2" src="img2.jpg" /> </div>

为了更易于比较,需要加一些简单的样式,如下所示:

div{border:1px solid black;/*给父元素添加一个边框,便于辨认*/ width:1000px; height:200px; font-size: 50px;/*设置大号字体,便于比较*/ } img#img1{ width:150px; } #span{ display: inline-block;/*注意这里的inline-block*/ width:250px; height:80px; background-color: yellow;/*给span元素设置一背景色,便于辨认*/ } img#img2{ width:250px; } 

因为vertical-align的默认值为baseline,所以以上代码相当于为#img1元素设置了vertical-align:baseline;属性。

W3Cbaseline值的解释是:默认,元素放置在父元素的基线上。

目前的效果大概是这样(黑色边框即为父元素div范围):

vertical-align:baseline; 辅助线

第二个属性值是vertical-align:top;,W3Ctop值的解释是:把元素的顶端与行中最高元素的顶端对齐。

本例中,最高元素即为图片2(#img2),如下所示:

vertical-align:top; 辅助线

第三个属性值是vertical-align:text-top;,W3Ctext-top值的解释是:把元素的顶端与父元素字体的顶端对齐。如下所示:

vertical-align:text-top; 辅助线

第四个属性值是vertical-align:middle;,W3Cmiddle值的解释是:把此元素放置在父元素的中部。

其实从下图可以看出,对齐的是父元素文本的中部:

vertical-align:middle; 辅助线

第五个属性值是vertical-align:bottom;,W3Cbottom值的解释是:把元素的顶端与行中最低的元素的顶端对齐。

本例中,行中最低元素即为span元素,如下所示:

vertical-align:bottom; 辅助线

第六个属性值是vertical-align:text-bottom;,W3Ctext-bottom值的解释是:把元素的底端与父元素字体的底端对齐。如下所示:

vertical-align:text-bottom; 辅助线

可以使用定长表示元素底部与父元素基线(baseline)的距离,如vertical-align:20px;

正值表示往上,负值表示往下,如下所示:

vertical-align:20px; 辅助线
vertical-align:-20px; 辅助线

亦可使用百分数表示元素底部相对于父元素基线(baseline)移动相对于父元素高(height)的百分比,如vertical-align:40%;

同样的,正值表示往上,负值表示往下,如下所示:

vertical-align:40%; 辅助线

不仅可以将vertical-align属性应用在图片上,也可以应用 在其它行内(内联)元素上

如此例,把vertical-align:top;运用在span元素上,如下所示:

将vertical-align运用在内联元素上 辅助线

垂直居中

从上文的示例分析可以看出,vertical-align属性虽有很多个可能的值

我们可以利用它的middle值,构造出令不定高的行内(内联)元素在父元素中垂直居中的效果

只需要在需要居中的元素外增加一个空的span元素

span元素display:inline-block;width:1px;height:100%;并添加vertical-align:middle;

将需要垂直居中的元素(本例中为#img1元素)添加vertical-align:middle;

为了将元素水平居中,可以在它的父元素(本例中为div元素)设置text-align:center;

目前的HTML结构看起来可能像这样:

<div><span id="span"></span> <img id="img1" src="testImg1.jpg" /> </div>

目前的CSS应该像这样:

div{width:1000px;height:200px; text-align: center; } img#img1{ vertical-align: middle; } #span{ display: inline-block; width:1px; height:100%; vertical-align: middle; }

效果会像这样:

垂直居中 辅助线

第二种用法

其实,vertical-align属性还有第二种用法

vertical-align可以用在display:table-cell;元素的下面(典型的就是td),这时的有四个可取值baseline|top|middle|bottom如下图

垂直居中 辅助线

这种用法相对比较简单,在此不再展开赘述。

 

感谢阅读

转载于:https://www.cnblogs.com/vivaloki/p/5567783.html

这篇关于[转]CSS vertical-align属性详解 作者:黄映焜的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/415919

相关文章

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库

Linux之软件包管理器yum详解

《Linux之软件包管理器yum详解》文章介绍了现代类Unix操作系统中软件包管理和包存储库的工作原理,以及如何使用包管理器如yum来安装、更新和卸载软件,文章还介绍了如何配置yum源,更新系统软件包... 目录软件包yumyum语法yum常用命令yum源配置文件介绍更新yum源查看已经安装软件的方法总结软

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni