你的垂直居中有问题?我竞无法反驳 🤦🏻‍♂️

前言

我们平常实现的垂直居中不是真正的垂直居中?何出此言!很多时候,往往自己明明正确的实现了垂直居中,但是 UI/UX 依旧说你的垂直居中有问题,然后自己仔细一看确实好像在视觉效果上存在一些偏差,但是仔细看自己实现的垂直居中代码却丝毫没有问题。今天我们就探讨一下这个有趣问题的由来、解决方案以及文字排版的未来。

Github 👈

发现问题

垂直居中的方式有很多种,这里我们在父级元素使用 display:flex;align-items:center 属性对子元素进行垂直居中,如下图:

似乎这个垂直居中已经非常完美了,但是你却收到了来自 UI/UX 的反馈和质疑

UI/UX:咦?你这垂直居中有问题~🥴

开发:哪里有问题,代码完全没有问题啊~

UI/UX:不信你自己看,文字的上半边空白部分比下半边多了 1px

开发:还真是...😑终究是逃不过设计的眼睛啊~

而我们真正想要效果是下面这样的

初探问题

细心的小伙伴,马上就会发现啊,罪魁祸首就是文本的 line-height 这个属性。那我们现在用 <p> 包含三个不同 font-family<span> 得到了下图这样的效果,对 font-size 相同的 font-family 不同的文本元素会产生具有不同高度。


问题找到了,导致垂直居中只是近似垂直居中的根本原因就是 line-height!在标准的文本框中,实际上文本上方和下方总是会有多余的空间,默认行高保留的多余空间会导致文本不总是在文本框中居中。因此,我们实现的垂直居中会存在不符合预期的情况,line-height 越大,问题就会越明显。同时,不同的字体,默认的 line-height 也会不同,因此,在字体大小,行高和文本框位置不变的情况下,更改字体也会导致文本的对齐结果。

🤯 这个问题就到此为止了吗?不,我们还不知道 line-height 为什么是这样的,以及为什么要这样。🤷🏻‍♂️

追根溯源

大约140年前,印刷术仍然使用单个引线盒手动设置字体。在印刷时,为了使文本更具可读性,排字机将铅条(leading)插入空格线。因此,打印的文字高度加上铅条的高度的总和就是总行高。


80 年代早期的图形设计软件保留了相同的传统,人们可以直接添加底部 leading 来控制基线之间的间距,同时也导致 line height 的增加。其他软件则让人们可以在直接调整行高。例如,在 1990 年发布的 Photoshop 的第一个版本中,用户可以定义 leading 的值,然后将其添加到字体大小中。许多工具也开始两个基线之间的距离叫做 line-height

1989 年,当 Bert Bos 和 HåkonWium Lie 起草 CSS 的第一个提案时,起初他们仍然遵循印刷世界的“旧”方式。但是很快,他们将决定做出合乎逻辑的又是根本性的改变,将 leading 一分为二,并将其放在每行的上方和下方,称其为 “half-leading”。为什么要这样做呢?目的就是为了使文本框看起来均匀(https://www.w3.org/TR/CSS1/#the-height-of-lines)。

”half-leading“ 非常取巧的避免了上下边框的不均匀性,但是同时也带来了一些问题。字体系列中的每种字体大小都带有默认的行高。为了容纳某些字符和重音符号,通常会将默认行高设置的高于其包含的文字。增加默认行高后再增加两个 “half-leading”,这样使得文本框变得更大了。这样一顿操作下来,就是我们现在面临文本无法垂直居中最根本的原因了。

多年来,Web 设计工具一直不支持半领先技术,因此,许多团队讨论了为什么屏幕设计和浏览器之间的布局差异如此之大。最重要的是,并不是每个人都知道这种复杂的技术细节,这经常导致设计师和开发人员之间容易发生一些口角🤦🏻‍♂️

解决方案

手动调整相关 CSS 属性

手动调整相关 CSS 属性,但是这样会出现一系列魔幻的 margin 或者 padding 的值,同时过于随机,并且只针对特定的字体、浏览器、操作系统。很明显这不是一个很好的解决方案。

裁剪工具

EightShapes Text Crop Tool

从工具中选择一种字体或加载自定义字体,然后使用滑块测量所需的顶部和底部裁剪。该工具会计算属性和公式,只需将生成的 SCSS,LESS 或 Stylus mixin 复制并粘贴到源代码中。

为什么只能针对一种字体,而不是所有字体都使用呢?

工具原理是通过 before 和 after 伪元素来定义负边距,这种做法在保留多行文本块中的行之间的行高的同时,删除了顶部和底部的空白。

// Top crop:
$ top-crop +($ desired-line-height-$ line-height-crop)*($ font-size-with-crop / 2)),0)/ $ font-size-with-crop;
//Bottom crop:
$ bottom-crop +($ desired-line-height-$ line-height-crop)*($ font-size-with-crop / 2)),0)/ $ font-size-with-crop;

最终结果是一个混合字体,无论字体大小如何都可以工作,并且只需要无单位的行高即可执行计算。但是将 mixin 应用于其他字体时,效果却不太好。

工具实现的是将 Em Square 裁剪为字体的 baseline 和 cap height,但是,每种字体都有不同的 Em Square Definition。因此,适用于一种字体的 “magic numbers” 不一定适用于其他字体。

新的 CSS 草案

很早开始就有很多人碰到了类似的问题,并且向 W3C 进行了反馈,我们不是第一个遇见这个问题的人。

为修复 CSS 文本布局相关问题,Leading-trim 成为了 CSS 内联布局草案的一部分

h1 { 
 text-edge: cap alphabetic;
 leading-trim: both;
}

借助 leading-trim,最终可以解决在网站上看到的所有神秘的对齐问题。可以在不破坏设计意图的情况下更换字体。



以下是是 leading-trim 属性相关草案(尚未成为规范

Ref

Leading-Trim: The Future of Digital Typesetting
The 4px baseline grid — the present
Getting to the bottom of line height in Figma
The Thing With Leading in CSS
Intro to Font Metrics
Deep dive CSS: font metrics, line-height and vertical-align
CSS Inline Layout Module Level 3
Cropping Away Negative Impacts of Line Height
css-inline Leading control at start/end of block #3240

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351