资讯专栏INFORMATION COLUMN

vertical-align,今晚来我房间聊聊剧本

Tychio / 1322人阅读

摘要:在阅读,更有味道哦,今晚来我房间聊聊剧本作者博客还是来点个吧,啊,各位吴彦祖和高圆圆写在前面最令人困惑的属性是什么因为它总是达不到我们想要的效果一个加一个标题,一个头像加一个名字,要让它们俩垂直居中一通乱试之后,是不是只能恼怒的用或者今

在GitHub阅读,更有味道哦:vertical-align,今晚来我房间聊聊剧本

作者博客:blog

还是来GitHub点个Star吧,啊,各位吴彦祖和高圆圆?

写在前面

CSS最令人困惑的属性是什么?vertival-align

因为它总是达不到我们想要的效果

一个logo加一个标题,一个头像加一个名字,要让它们俩垂直居中

一通乱试之后,是不是只能恼怒的用float或者marginpadding

今天,我们就来好好调教一下vertival-align这个傲娇女神

概念

line box

由若干行内元素占据的一行,会有一个虚拟的框,该行所有行内元素都在这个框里面,W3C把这个框叫做line box

line box的高度由里面最高的行内元素撑起

如果里面行内元素的总宽度超过一行,则换行显示

text box

假如line box里面有一个英文字母x,这个字母的所有属性均继承自父元素

你把字母x用span包裹起来,设置背景颜色,背景颜色覆盖的高度就是text box的高度

当然,它是由font-sizeline-height共同决定的

text box是有其实的,你看那字母x明晃晃的背景颜色

只不过名字是我杜撰的,跟line box对应

W3C叫它父元素的文字,我觉得不是很好理解

金线

vertival-align是垂直对齐属性,那它是跟谁对齐呢?

肯定是跟line box相关的某条线对齐,我把它叫做金线

我们都知道,小写字母x落在text box的基线上,小写字母g落在text box的底线上

字母x的下边缘就是vertival-align: baseline;所要对齐的金线

金线这个名字也是我取的,因为它是一个准绳

其实说白了vertival-align默认值对齐的就是text box的基线,所以它跟父元素的font-sizeline-height都有关系

本文不讨论它们之间的关系,假设父元素的font-sizeline-height都是固定的

当然不同的属性值,金线的标的也是不一样的,后面会讲到

金线虽然是一个准绳,它却没什么骨气,有时候会去迁就比较高的行内元素

inline元素和inline-block元素

vertival-align只对这两种元素(或者变种)有效

一招鲜

咱们先来一个命中率极高的解决方案

回到最前面的问题:一个logo加一个标题,一个头像加一个名字,要让它们俩垂直居中

biu

你给spanvertical-align: middle;,可是达不到效果

你给imgvertical-align: middle;,还是达不到效果

不是说好的垂直居中嘛,无赖呀!

其实,你给它们俩都加上vertical-align: middle;试试,效果是不是出来了?

我们潜意识肯定认为vertical-align是相对另一个元素对齐,否则怎么会期望达到我们想要的效果呢?

因为vertical-align是相对金线对齐,每个元素都要分别设置才能统一实现垂直居中

那你说我写在父元素上可不可以?

想走捷径,可以

你在父元素上写vertical-align: middle;,然后你还要在每一个行内元素上写vertical-align: inherit;

因为vertical-align默认是不继承的

惊不惊喜!

当然,如果父元素显式的设置了高度,并且比里面任何行内元素都要高,那一招鲜也蔫了,后面有例子

属性值



x top x bottom x text-top x text-bottom x middle x baseline x baseline visible x

通过这张图,我们来聊一聊不同属性值所对应的金线是什么

top: 金线所在的位置是line box的上边

bottom: 金线所在的位置是line box的下边

text-top: 金线所在的位置是text box的上边,也就是字母x背景颜色的上边

text-bottom: 金线所在的位置是text box的下边,也就是字母x背景颜色的下边

middle: 金线所在的位置是字母x的中部,也就是叉相交的地方

baseline: 金线所在的位置是字母x的下边

需要注意的是,最后一个矩形和前一个矩形都是vertical-align: baseline;,不同的是最后一个矩形overflow的属性值是visible

而前面所有矩形都是overflow: hidden;

为什么呢?

因为如果行内元素里面有文字,而行内元素的垂直对齐又是默认值时,是以行内元素里面最底部的文字基线和text box的基线对齐

然而如果设置了overflow: hidden;,就会触发BFC,文字就不会影响对齐点了

我是为了附上文字,方便比较,所以让前面的矩形都触发了BFC

一个例子

我希望实现图片垂直居中,怎么弄?

直接给图片设置vertical-align: middle;肯定是不行的

因为图片比较高,金线会去迁就图片

结果就是图片纹丝不动,字母x对齐图片中间



x

我看到网上有一篇文章是这样做的

加一个span标签,变成inline-block元素,高度和父元素一样高,宽度1px,如果没有背景颜色,它几乎可以忽略不计

然后给图片和这个span同时设置vertical-align: middle;

哎,发现真的可行

他解释说图片需要一个居中对齐的标杆,所以生造一个span,就可以使图片居中了

效果是达到了,然而解释是错误的

图片对齐span,那span对齐谁呢?

其实图片和span都是对齐金线,因为span的高度和父元素的高度一致,金线为了迁就它,就跑到父元素中间去了。然后图片再去对齐金线,于是图片也居中了

标杆永远是金线,只不过金线的位置是动态计算的,有时候要去迁就比较高的行内元素



x

其实还有一种办法,给父元素设置行高等于高度

这时候text box的高度和父元素的高度是一样的,金线不需要去迁就任何人,图片只管对齐它就是了



x
总结

首先,line box里有一个text box,同时还有一根金线

不同的垂直对齐属性值,对标的金线是不同的,所以多个元素可能对标多根金线,这是没问题的

金线虽然是准绳,但它的高度是动态计算的,有可能要去迁就很高的行内元素

如果行内元素里面有文字,且属性值为baseline的时候,是以里面文字的基线去对齐金线

但如果触发BFC,则上一条失效

张鑫旭讲到过,middle只是近似垂直居中,有兴趣的可以去了解一下

如果金线跟text box有关,你可以在line box里放一个没有任何样式的小写字母x,给它一个背景色(好吧背景色也是样式),方便查看金线大概在哪里

金线,当它是text box的一部分时,肯定跟父元素的font-sizeline-height是有关的,这个以后咱么再聊

其实大多数情况,一招鲜都可以解决,就是给所有行内元素设置垂直居中

总之,找到金线,你就找到组织了

写在后面

我和你们一样,每次见到一行有多个行内元素就犯怵

所以下定决心弄清楚vertical-align的原理,希望对大家有一点微小的启发

以上都是我自己的理解,金线也是我自创的,可能不是很严谨

CSS是一门玄学,够用就好

在GitHub阅读,更有味道哦:vertical-align,今晚来我房间聊聊剧本

作者博客:blog

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

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

相关文章

  • 大话爬虫的基本套路

    摘要:有什么作用通过有效的爬虫手段批量采集数据,可以降低人工成本,提高有效数据量,给予运营销售的数据支撑,加快产品发展。因为信息是完全公开的,所以是合法的。 showImg(https://segmentfault.com/img/remote/1460000011359885?w=566&h=316);   什么是爬虫? 网络爬虫也叫网络蜘蛛,如果把互联网比喻成一个蜘蛛网,那么蜘蛛就是在...

    Towers 评论0 收藏0
  • 解析类Dota游戏天梯匹配系统的实现方式

    摘要:提供房间最大人数游戏模式,默认为允许观战,默认不允许固定字段。服务端收到请求后,将完全按照进行匹配,即将携带相同的的玩家匹配到一起。提供创建房间的接口用于玩家创建房间,玩家主动创建的房间和系统自动创建的房间隔离。 什么是类Dota游戏的天梯匹配 玩过Dota或者LOL的人都知道 . 天梯匹配系统是一套将 玩家的实力 量化,并进行实时分配组队游戏 , 结算的系统. 旨在将单局游戏的胜率控...

    weakish 评论0 收藏0
  • 使用 ink + react 制作一个命令行的在线五子棋游戏客户端

    摘要:背景是在命令行中渲染系统的一个实现在上已经有看着蛮好玩因此尝试着写了一个五子棋游戏经过若干天的划水终于初见成效了先来看个演示动画太大这里放不下请移步观看需要声明的是这个客户端我已经开源在了上地址是但是这是一个在线游戏的客户端因为商业原因服务 背景 Ink 是 React 在命令行中渲染系统的一个实现, 在 GitHub 上已经有 1w+ Star. 看着蛮好玩, 因此尝试着写了一个五子...

    macg0406 评论0 收藏0
  • 什么是云服务器?

    云服务器是一种简单高效、安全可靠、处理能力可弹性伸缩的计算服务。其管理方式比物理服务器更简单高效。用户无需提前购买硬件,即可迅速创建或释放任意多台云服务器。用一个比喻形象的来描述云服务器,云服务器就好比是一个酒店,每一个租户都会有一个独立的房间,可以自己去操作。(房间的大小根据价格来定,也是就配置的高低)比起传统的服务器的价格更低,租户操作起来更简单。用一句话来概括云服务器的优势,就是实现了主机租...

    guangyi 评论0 收藏0

发表评论

0条评论

Tychio

|高级讲师

TA的文章

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