摘要:在阅读,更有味道哦,今晚来我房间聊聊剧本作者博客还是来点个吧,啊,各位吴彦祖和高圆圆写在前面最令人困惑的属性是什么因为它总是达不到我们想要的效果一个加一个标题,一个头像加一个名字,要让它们俩垂直居中一通乱试之后,是不是只能恼怒的用或者今
在GitHub阅读,更有味道哦:vertical-align,今晚来我房间聊聊剧本写在前面作者博客:blog
还是来GitHub点个Star吧,啊,各位吴彦祖和高圆圆?
CSS最令人困惑的属性是什么?vertival-align
因为它总是达不到我们想要的效果
一个logo加一个标题,一个头像加一个名字,要让它们俩垂直居中
一通乱试之后,是不是只能恼怒的用float或者margin、padding
今天,我们就来好好调教一下vertival-align这个傲娇女神
概念line box
由若干行内元素占据的一行,会有一个虚拟的框,该行所有行内元素都在这个框里面,W3C把这个框叫做line box
line box的高度由里面最高的行内元素撑起
如果里面行内元素的总宽度超过一行,则换行显示
text box
假如line box里面有一个英文字母x,这个字母的所有属性均继承自父元素
你把字母x用span包裹起来,设置背景颜色,背景颜色覆盖的高度就是text box的高度
当然,它是由font-size和line-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-size和line-height都有关系
本文不讨论它们之间的关系,假设父元素的font-size和line-height都是固定的
当然不同的属性值,金线的标的也是不一样的,后面会讲到
金线虽然是一个准绳,它却没什么骨气,有时候会去迁就比较高的行内元素
inline元素和inline-block元素
vertival-align只对这两种元素(或者变种)有效
一招鲜咱们先来一个命中率极高的解决方案
回到最前面的问题:一个logo加一个标题,一个头像加一个名字,要让它们俩垂直居中
biu
你给span加vertical-align: middle;,可是达不到效果
你给img加vertical-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-size和line-height是有关的,这个以后咱么再聊
其实大多数情况,一招鲜都可以解决,就是给所有行内元素设置垂直居中
总之,找到金线,你就找到组织了
写在后面我和你们一样,每次见到一行有多个行内元素就犯怵
所以下定决心弄清楚vertical-align的原理,希望对大家有一点微小的启发
以上都是我自己的理解,金线也是我自创的,可能不是很严谨
CSS是一门玄学,够用就好
在GitHub阅读,更有味道哦:vertical-align,今晚来我房间聊聊剧本作者博客:blog
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/113002.html
摘要:提供房间最大人数游戏模式,默认为允许观战,默认不允许固定字段。服务端收到请求后,将完全按照进行匹配,即将携带相同的的玩家匹配到一起。提供创建房间的接口用于玩家创建房间,玩家主动创建的房间和系统自动创建的房间隔离。 什么是类Dota游戏的天梯匹配 玩过Dota或者LOL的人都知道 . 天梯匹配系统是一套将 玩家的实力 量化,并进行实时分配组队游戏 , 结算的系统. 旨在将单局游戏的胜率控...
摘要:背景是在命令行中渲染系统的一个实现在上已经有看着蛮好玩因此尝试着写了一个五子棋游戏经过若干天的划水终于初见成效了先来看个演示动画太大这里放不下请移步观看需要声明的是这个客户端我已经开源在了上地址是但是这是一个在线游戏的客户端因为商业原因服务 背景 Ink 是 React 在命令行中渲染系统的一个实现, 在 GitHub 上已经有 1w+ Star. 看着蛮好玩, 因此尝试着写了一个五子...
阅读 1460·2019-08-30 15:44
阅读 1927·2019-08-30 14:07
阅读 2852·2019-08-30 13:56
阅读 2320·2019-08-29 17:06
阅读 1295·2019-08-29 14:13
阅读 2053·2019-08-29 11:28
阅读 3199·2019-08-26 13:56
阅读 1923·2019-08-26 12:11