CSS 自定义字体垂直偏移(错误?)
Posted
技术标签:
【中文标题】CSS 自定义字体垂直偏移(错误?)【英文标题】:CSS custom font vertical offset (bug?) 【发布时间】:2012-06-01 17:20:48 【问题描述】:我通过这种方法在我的 CSS 中使用自定义字体:
@font-face
font-family: 'Gabriola';
src: url('Gabriola.eot');
src: url('Gabriola.eot?#iefix') format('embedded-opentype'),
url('Gabriola.woff') format('woff'),
url('Gabriola.ttf') format('truetype');
font-weight: normal;
font-style: normal;
.gabriola
font-size: 20px;
line-height: 20px;
height: 20px;
background: red;
<div class="gabriola">Some texty text here</div>
每个浏览器都以自己的方式呈现这些字体,垂直偏移顶部和底部像这样
我做错了什么?谢谢
【问题讨论】:
不确定问题出在哪里,但您是否尝试过使用span
代替? (或任何其他内联元素,而不是块元素)
【参考方案1】:
如果有人遇到问题并且不想或无法重建字体,这就是解决方案: https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/ascent-override
这个道具会在字体导入时调整垂直升序属性。
【讨论】:
【参考方案2】:我知道 OP 提出这个问题已经 5 年了,但我发现了这种让文本基线正确对齐的好方法。
基本上,文本容器必须是行高为 0 的内联块; 然后,你创建一个 inline-block 伪元素并根据你想要的 line-height 设置它的高度:
span
font-size: 2em;
background: red;
span.baseline-align
vertical-align: baseline;
span.true-baseline-align
display: inline-block;
line-height: 0;
span.true-baseline-align::after
content: '';
display: inline-block;
height: 1em; // this is where you control line-height
<span>Normal text</span>
<br><br>
<span class="baseline-align">With vertical-align: baseline</span>
<br><br>
<span class="true-baseline-align">with trick to really baseline-align</span>
http://blogs.adobe.com/webplatform/2014/08/13/one-weird-trick-to-baseline-align-text/
【讨论】:
虽然此链接可能会回答问题,但最好在此处包含答案的基本部分并提供链接以供参考。如果链接页面发生更改,仅链接答案可能会失效。 - From Review 谢谢!我改变了我的答案:) 这太天才了!感谢分享这个小技巧:) 注意此解决方案仅适用于单行。如果您的句子跨越多行(可能与网络的响应性质有关),那么它会重叠自身。【参考方案3】:我遇到了同样的问题,解决方案是使用原始属性重建字体,而无需使用 Hight 逻辑字体创建器更改新文件中的任何内容,字体未更改且等于原始问题已更正并对齐在包括 ie6 在内的所有浏览器中,完美的工作是几个小时的工作,但如果您需要一些用户,这是结果。
http://www.filefactory.com/file/1miw29cddg21/n/crossbrowser_gabriola_font.zip
【讨论】:
您是说您在“高度逻辑字体创建器”中打开了字体并调整了每个字母的间距,还是您只是打开了字体并使用该应用程序重新导出了它? (考虑使用多个句子)【参考方案4】:您可能没有做错任何事情。以下是一些可能适用的要点,有些可以由您控制,有些则不能。
-
为了确定,明确设置
vertical-align: baseline
。
不同的文件(.eof
、.woff
、.ttf
)本身可能定义不一样,因此不同的浏览器使用的文件不同,显示的也不同。
不确定是否有两个 src
电话会搞砸,但您可以尝试消除第二个:
@font-face
font-family: 'Gabriola';
src: url('Gabriola.eot'),
url('Gabriola.eot?#iefix') format('embedded-opentype'),
url('Gabriola.woff') format('woff'),
url('Gabriola.ttf') format('truetype');
font-weight: normal;
font-style: normal;
这些都只是猜测。您将不得不测试 #1、3。如果问题是 #2,我不确定是否有一个优雅的解决方案。
当然,this site 有一个警告:
请记住,字体渲染在不同浏览器和 操作系统。许多开发人员都经历过如此糟糕的结果 来自 Windows 和 Internet Explorer,他们避免使用自定义字体 共。始终确保仔细检查所有结果 您可以决定质量是否可以接受的浏览器。
更新
This post 提供了一些关于可能解决渲染问题的提示。这是给 Font Squirrel 的,他特别指出:
如果您下载了该套件,您可以尝试使用重新生成字体 发电机。我们对生成器进行定期调整 可能会改善字体的提示或渲染。
但他也确认,
不要推卸责任,但最常见的原因是原件不好 字体。
这与我的第 2 点相符。
【讨论】:
感谢您的回答..在所有浏览器中都不相同的原因是字体。我尝试了 5 种字体类型,但只有 Gabriola 有垂直偏移错误。所以我想这都是关于字体“质量”的。 第 3 点是错误的。 Explorer 总是使用最后一个字体文件,所以我们需要两个单独的src
。以上是关于CSS 自定义字体垂直偏移(错误?)的主要内容,如果未能解决你的问题,请参考以下文章