css html深入,HTML和CSS进阶:深入vertical-align

vertical-align,很多人对这个属性感到很陌生,也不知道怎么去使用,其实这都是由于没有深入属性的本质所导致的。vertical-align属性非常复杂,但是也相当强大。这一节给大家介绍vertical-align属性最实用的技巧,而对于不常用的东西则不进行深入研究。

W3C官方对vertical-align属性的定义有4个方面:

(1)vertical-align属性用于定义“周围的文字、inline元素以及inline-block元素”相对于该元素基线的垂直对齐方式。这里的“该元素”指的是被定义了vertical-align属性的元素;

(2)在表格单元格中,vertical-align属性可以定义单元格td元素中内容的对齐方式。td元素是table-cell元素,也就是说vertical-align属性对table-cell类型元素有效;

(3)vertical-align属性对inline元素、inline-block元素和table-cell元素有效, 对block元素无效;

(4)vertical-align属性允许指定负长度值(如-2px)和百分比值(如50%);

从上一节我们知道,每一行文字可以看成一个行盒子,其实每一个inline-block元素也可以看成一个行盒子。其中,每一个行盒子都有4条线:(1)顶线;(2)中线;(3)基线;(5)底线。这4条线跟英文簿中的4条线是相似的。

123352jjy2hx1i0y02qixx.png

vertical-align属性中的“基线”跟line-height属性中的基线是一样的道理。在CSS中,vertical-align属性最见的属性值有4个:top(顶部对齐)、middle(中部对齐)、baseline(基线对齐)、bottom(底部对齐)。

一、 vertical-align属性取值

vertical-align属性取值有3种情况:(1)负值;(2)百分比;(3)关键字。

1、负值

vertical-align属性取值可以为负值,例如“vertical-align:-2px”表示元素相对于基线向下偏移2px。此方法常常用于解决单选框或复选框与文字垂直对齐的问题。对于这个技巧,我们在下一章“表单效果”会详细介绍。

2、百分比

vertical-align属性取值可以为百分比,这个百分比是相对于当前元素所继承的line-height属性值决定的。

举个例子,对于“vertical-align:50%”,假如当前元素所继承的line-height为20px,则“vertical-align:50%”实际上等价于“vertical-align:10px”。其中, vertical-align:10px”表示元素相对于基线向上偏移10px。

3、关键字

vertical属性取值可以为关键字,取值如下:

取值         说明

top                顶部对齐

middle        中部对齐

baseline        基线对齐

bottom        底部对齐

除了以上这些,vertical-align属性取值还可以为text-top、text-bottom、super、sub等关键字。不过其他关键字在实际开发中很少用得上,因此我们只需要掌握top、middle、baseline、bottom这4个属性值就行。

举例:

vertical-align属性

img{width:80px;height:80px;}

#img1{vertical-align:top;}

#img2{vertical-align:middle;}

#img3{vertical-align:bottom;}

#img4{vertical-align:baseline;}

绿叶学习网绿叶学习网(top)


绿叶学习网绿叶学习网(middle)


绿叶学习网绿叶学习网(bottom)


绿叶学习网绿叶学习网(baseline)

在浏览器预览效果如下:

123402yo01xwum10mggyew.png

分析:

根据W3C的定义“vertical-align属性用于定义周围文字、inline元素或inline-block元素的基线相对于该元素的基线的垂直对齐方式”。在这个例子中,vertical-align属性定义了周围的文字相对于img元素基线的垂直对齐方式。

此外,“vertical-align:baseline”和“vertical-align:bottom”是有区别的,请仔细观察预览效果。

二、vertical-align属性应用

我们从以下3个方面来介绍一下vertical-align属性的使用情况:(1)inline-block元素;(2)inline元素和block元素;(3)table-cell元素。

1、inline元素和inline-block元素

在HTML中,常见的inline-block元素有2个:img元素和input元素。对于这两个inline-block元素,我们一定要记住。

举例:

strong

{

font-size:40px;

border:1px solid red;

}

span{font-size:12px;}

绿叶学习网绿叶学习网绿叶学习网

在浏览器预览效果如下:

123355jy9uy7xy9gx7r911.png

分析:

当我们在CSS中为strong元素添加“vertical-align:center;”之后,浏览器预览效果如下:

举例:

img{vertical-align:middle;}

绿叶学习网 绿叶学习网( middle)

在浏览器预览效果如下:

123400y8zdd7hcnshc9hvm.png

2、block元素

vertical-align属性对inline元素、inline-block元素和table-cell元素有效,对block元素无效。

举例:

div

{

vertical-align:middle;

width:120px;

height:120px;

border:1px solid gray;

}

在浏览器预览效果如下:

123358wu6aq2qrozoo5q86.png

分析:

div是block元素,所以vertical-align属性对其无效。如果想要在div中实现图片的垂直居中,我们可以先为div定义“display:table-cell”,也就是将block元素转化为table-cell元素(表格单元格),然后再使用“vertical-align:middle”就可以实现了。

举例:

div

{

display:table-cell;

vertical-align:middle;

width:120px;

height:120px;

border:1px solid gray;

}

在浏览器预览效果如下:

123358pnn96hshisfn9dzs.png

分析:

在div中实现图片垂直居中是很常见的技巧,我们在后续章节会给大家介绍更多垂直居中的技巧。

3、table-cell元素

W3C定义:在表格单元格中,vertical-align属性可以定义单元格中内容的对齐方式。也就是说vertical-align属性对table-cell类型元素有效。

这里要注意一下,table-cell元素跟inline、inline-block元素使用vertical-align是有很大区别的:

(1)inline元素和inline-block元素的vertical-align是针对周围的元素来说,vertical定义的是周围元素相对于当前元素的对齐方式;

(2)table-cell元素的vertical-align属性是针对自身而言。vertical-align定义的是内部子元素相对于自身的对齐方式;

举例:

td

{

width:120px;

height:120px;

border:1px solid gray;

vertical-align:middle;

}

在浏览器预览效果如下:

123400d8uuggnb8gibbgf9.png

【后话】:这一章学习到的知识,估计已经狠狠地给那些天天自诩“精通CSS”的同学几巴掌了。原来,CSS也是如此的博大精深,并非我们想象中那么简单。对于HTML、CSS和JavaScript这3大核心技术,还是希望大家能够踏踏实实地深入研究,这样我们的前端之路才有可能走得更远。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值