7

我正在尝试使用本网站的以下代码显示带有 SVG 的子标和上标

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<g>
    <text x = "10" y = "25" font-size = "20">
        <tspan>
            e = mc 
            <tspan baseline-shift = "super">2</tspan>
        </tspan>
        <tspan x = "10" y = "60">
            T 
            <tspan baseline-shift = "sub">i+2</tspan>
            =T 
            <tspan baseline-shift = "sub">i</tspan>
            + T 
            <tspan baseline-shift = "sub">i+1</tspan>
        </tspan>
    </text>
</g>

但子/上标不显示在 IE 或 Firefox 中。这是未实现还是有其他问题?[你能看到正确显示的下标吗?]

4

1 回答 1

13

IE9、IE10 和 Firefox 不支持 Baseline-shift,请参阅:

http://msdn.microsoft.com/en-us/library/gg558060(v=vs.85).aspx https://bugzilla.mozilla.org/show_bug.cgi?id=308338

如果您实际尝试显示公式,则更适合嵌入在 SVG 中的 MathML,请参阅:

http://www.maths-informatique-jeux.com/international/mathml_with_other_standards/index.php

如果您想要对您提供的示例进行快速修复,您可以使用dy...

<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<g>
    <text x = "10" y = "25" font-size = "20">
        <tspan>
            e = mc 
            <tspan dy ="-10">2</tspan>
        </tspan>
        <tspan x = "10" y = "60">
            T 
            <tspan dy="10">i+2</tspan>
            <tspan dy="-10">=T </tspan>
            <tspan dy="10">i</tspan>
            <tspan dy="-10">+ T</tspan> 
            <tspan dy="10">i+1</tspan>
        </tspan>
    </text>
    </g>
</svg>

​<a href="http://jsfiddle.net/UQ5Dp/" rel="noreferrer">http://jsfiddle.net/UQ5Dp/

于 2012-09-08T21:36:04.073 回答