Android版Chrome不支持first-letter
元素的CSS text
选择器。我创建了一个非常简单的SVG来演示这个问题。在桌面浏览器上,您会看到通过first-of-type
和first-letter
选择器创建的三种尺寸的文字。在Firefox for Android上你会看到同样的事情。但是在Chrome上,只会显示两种尺寸。
text {
font-size:50px;
}
text:first-of-type {
font-size:70px;
}
text:first-letter {
font-size:90px;
}
<svg version="1.1" baseProfile="full" width="520" height="200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink= "http://www.w3.org/1999/xlink">
<text x="0" y="80">MY WORDS</text>
<text x="0" y="160">MY WORDS</text>
</svg>
Caption http://codepen.io/Kelderic/pen/jefuq.svg
我的问题是,除了将单词拆分为多个text
元素并将大小应用于每个元素之外,还有其他简单的解决方法吗?
答案 0 :(得分:0)
你可以使用foreignObject,这样它只适用于支持它的UAs。不幸的是,这意味着支持foreignObject的Firefox获取了html代码,但也许没问题。
<svg version="1.1" baseProfile="full" width="520" height="200" xmlns="http://www.w3.org/2000/svg" xmlns:xlink= "http://www.w3.org/1999/xlink">
<switch>
<foreignObject requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" width="520" height="200">
<div>MY WORDS</div>
<div>MY WORDS</div>
</foreignObject>
<g>
<text x="0" y="80">MY WORDS</text>
<text x="0" y="160">MY WORDS</text>
</g>
<switch>
</svg>