我在x轴上用0,12,24,36等来定位每个字母。我希望每个字母的间距是均匀的,但事实并非如此。
const websiteName = "websitename".split('');
<svg width="180" height="36" style={{display:"block"}}>
{
[...websiteName].map((letter, i) => (
<text x={i*12} y="30" fontSize="22" key={i}>{letter}</text>
))
}
</svg>
字符串
它看起来是这样的:
的数据
原因是什么以及如何解决它?
1条答案
按热度按时间eufgjt7s1#
**示例1:**您可以考虑使用等宽字体,其中每个字符的宽度相同。如果您想坚持使用比例字体,您可以计算每个字母的宽度并相应地调整x坐标。这里是使用等宽字体的示例:
字符串
**示例2:**您可以计算所有字符的总宽度,然后平均分配空格。这里是您的代码的更新版本,以实现这一点:
型