html – 在span中包装字符“Y”,增加下一个字符的边距

前端之家收集整理的这篇文章主要介绍了html – 在span中包装字符“Y”,增加下一个字符的边距前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在我目前的项目中,我需要在一个范围内包装一个句子的每个单个字符,这样我就可以测量从句子开头到相关字符的距离.

不幸的是,似乎在一个跨度中包含一些字符(我发现它对于“Y”和“T”是真的),在右边添加了一个额外的边距,因此整个文本被拉伸:

div { font-size: 100px; }
<h2>Expected (same width):</h2>
<div>A-A-A-A</div>
<div>
  <span>A</span><span>-</span><span>A</span><span>-</span><span>A</span><span>-</span><span>A</span>
</div>

<h2>Unexpected (different width):</h2>
<div>Y-Y-Y-Y</div>
<div>
  <span>Y</span><span>-</span><span>Y</span><span>-</span><span>Y</span><span>-</span><span>Y</span>
</div>

如果你运行代码片段,你会发现,当包装在SPAN中时,“Y-Y-Y-Y”明显更宽.

为什么会这样?我该如何防止这种行为?

解决方法

您可以通过设置font-kerning来解决这个问题:无;到了div

Like this

div { font-size: 100px; font-kerning: none; }

https://developer.mozilla.org/en-US/docs/Web/CSS/font-kerning

猜你在找的HTML相关文章