资讯专栏INFORMATION COLUMN

关于 vertical-align 的一些理解

lowett / 2472人阅读

摘要:关于的条参考线以及。关于和之间的关系。目标元素的的垂直平分线,与父元素内匿名的对齐。垂直平分线,这个容易理解。要比这些字母的顶端再高一些。

前言

关于 vertical-align,我们很容易想到,这不就是告诉我们元素在纵向上和什么对齐的属性吗?而事实上,正是这种宽泛的说法导致了我们对其的理解存在许多不确定性。事实上,“对齐”这两个字其实牵涉到4个对象:即哪个对象的哪条线,与哪个对象的哪条线对齐?只有将这4者搞清楚,我们才能说是理解了这个属性。

我们知道,vertical-align 有以下几类可选值:

文字:baseline、top、bottom、text-top、text-bottom、middle、sub、super

百分比

数字

其中,文字是最多的,现在我就以文字为例,来探讨以下vertical-align究竟是怎么对齐的。在阅读之前,有一些预备知识应该是必不可少的,它们是:

关于行内元素的4种box模型:containing boxes、inline boxes、line box 以及 content area。

关于 font-size 的 4 条参考线:topline、bottomline、baseline以及middleline。

关于 font-size 和 line-height 之间的关系。

以上知识可以在以下文章中看到
深入了解css的行高Line Height属性

下面是这次我使用的例子。
html:

0.Eng2lish3 Englishx

css:

.box{
    border: 1px solid #555;
    font-size: 28px;
    height:150px;
    line-height: 100px;
}
.span{
    display: inline-block;
    background-color: #ffffd;
    font-size: 50px;
    margin-right: 35px;
    line-height: 80px;
}
vertical-align:top

目标元素的 inline-box 的顶端边缘,与父元素的 line-box 的顶端边缘对齐。这很好理解。

vertical-align:bottom

目标元素的 inline box 的底端边缘,与父元素的 line-box 的底端边缘对齐。同样很好理解。

不过,这里有同学说了:不对啊,图片里目标元素的底端没有和父元素的底端对齐啊!注意,上面写的是与父元素的 line-box 的底端边缘对齐。那么父元素的底端边缘在哪里呢?并不是在下边框这里。这是因为,下边框是被父元素的 height 属性撑开的,父元素的 line box 的高度,是由 line-height 属性决定的。注意看上面的 css。这里的 line-height 比 height 要小,所以目标元素的底部达不到父元素的下边框。

还有一部分眼尖的同学说,还是不对呀,我目测了一下,你 css 里设置的 line-height 是 100px。但是这里目标元素的底部,离父元素的顶部似乎要大于 100px 呀?是的,你说的没错。实际上这个数字是118px,原因是,内部匿名inline box 的上标(3)和下标(2)把这个匿名 inline box 的line-height 撑大了,导致其实际 line-height 达到了 118px。如果把上标下标去掉,那就完美符合啦。

vertical-align:middle

目标元素的 inline-box 的垂直平分线,与父元素内匿名inline boxes的 middleline 对齐。这个属性恐怕是实战中使用最频繁的属性了。

这里出现了几个新东西,需要多说几句。垂直平分线,这个容易理解。那什么是“父元素内匿名inline boxes,什么又是“父元素内匿名 inline boxes 的 middleline”?

首先,父元素内匿名inline boxes,你可以假设成直接写在父元素内的纯文字。由于它被父元素直接包裹,所以各种属性,包括line-height 和 font-size 等等,都是直接继承自父元素。当然,父元素内未必真的存在文字,它内部可能没有任何匿名inline boxes,但是,当 vertical-align 参与计算的时候,所参照的就是这个可能并不存在的匿名inline boxes。

好了,轮到 middleline。middleline 之前被我放在了预备知识里,这里再多引申一点。按照规范,middleline 是文字的 baseline 往上方挪 1/2 个 x字母高度 的位置,所在的那条线。这条线并不是content area的严格中线,但和真正几何位置的中线很接近。

为了更清楚地表示 middleline 的位置,我这里多加了3个 x 字母,很明显,middleline 穿过字母 x 的中央。

好了,理解了 vertical-align:middle ,我们再理解下面几个属性就简单多了。

vertical-align:text-top

目标元素的 inline-box 的顶部边缘,与父元素内匿名 inline boxes 的顶线,topline对齐。这里要注意,topline 在视觉上并不和l、h这些高字母的顶端对齐,这是因为这些字母的高度都没有达到topline。topline 要比这些字母的顶端再高一些。

vertical-align:text-bottom

目标元素的 inline-box 的底部边缘,与父元素内匿名 inline boxes 的底线,bottomline对齐。和 topline 不同,像 g 这样的下沉字母的底端一般都会达到 bottomline 的位置。

vertical-align:baseline

这个默认属性反而放到后面来说?为什么?因为这里和上面有一点不同。在上面的情况下,目标元素参与对齐的参考线,都是 inline-box 的上下边缘,而这里是 baseline!

vertical-align:sub

目标元素的 inline-box 的 baseline,与父元素内下标(sub 标签)的 inline boxes 的 baseline 对齐。

vertical-align:super

目标元素的 inline-box 的 baseline,与父元素内上标(sup 标签)的 inline boxes 的 baseline 对齐。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/116426.html

相关文章

  • 关于vertical-align

    摘要:内联元素的外边缘与该行高的顶部和底部边缘对齐。如果行高小于字体的高度,不会受影响,但会对齐文本边界。红线表示边界,蓝线表示,黄色为,白色为区域,绿色为区域。的确定规则元素的是它的第一行的。 前言 为什么写这篇总结?最近在文字图标垂直对齐上用到css的vertical-align属性,但是有的时候有效,有的时候无效,常常疑惑不解,反思这是自己对vertical-align的基本认知不够造...

    kumfo 评论0 收藏0
  • [译]关于vertical-align:你需要知道一切

    摘要:绝对定位让元素脱离文档流,所以他们不再影响他们的周边元素。元素在文档流中,也能感知其他元素尺寸的改变。中间,一个在文档流中的元素并且带有属性的元素。最右,不在文档流中的元素但是内容区域有高度。元素的基线依赖于元素是否是文档流中的元素。 原文:Vertical-Align: All You Need To Know 通常我都有需要垂直对齐在一排上一个接着一个的元素。CSS提供了很多种可能...

    wuyangchun 评论0 收藏0
  • 关于css 垂直居中

    摘要:之前看了张大大的博客总结一下我对和的一些认知。站在巨人的肩膀上学习,再次谢谢张大大阮大大的各种分享。 对于元素的水平居中,我根据我自己之前的一些学习来进行一些总结,如果有不对的地方,欢迎指正~ 一、让大小不固定的元素垂直居中 因为:表格的单元格的特别属性:垂直居中等; `div.parent { display: table-cell; vertical-align...

    caspar 评论0 收藏0
  • 关于css 垂直居中

    摘要:之前看了张大大的博客总结一下我对和的一些认知。站在巨人的肩膀上学习,再次谢谢张大大阮大大的各种分享。 对于元素的水平居中,我根据我自己之前的一些学习来进行一些总结,如果有不对的地方,欢迎指正~ 一、让大小不固定的元素垂直居中 因为:表格的单元格的特别属性:垂直居中等; `div.parent { display: table-cell; vertical-align...

    icattlecoder 评论0 收藏0
  • 我脑中飘来飘去css魔幻属性

    摘要:先来一张图,看懂的几个属性顺便带上图片出处,文章讲得还可以,理解这张图片,后面就好理解了。元素根据标签的属性决定显示输入框还是按钮。还有,还有近来很火的。 最近看到一篇20 个CSS高级技巧汇总的汇总,感触很深,不过我想,与技巧相比,有些常见css布局难题,有时候更加让我们的日常开发变得踌躇沮丧吧。在写这一篇文章之前,自己还写过一篇:我所不注意的那些CSS冷知识,但却阻止了我做项目的速...

    JouyPub 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<