Ampersands (&) in xlink:href attributes of SVG images?

我是研究僧i 提交于 2019-12-07 01:26:35

问题


I'm building an SVG document which contains various image tags. The xlink:href (source URL) attributes for the images contain query strings with ampersands. If I escape them as %26 or the ascii encoding ? they're not valid query strings and the server won't deliver the image. I can't escape them with CDATA because they're attributes (not nodes). I've tried creating an xlink:href node within the image tag but that get's ignored by the SVG parser. I want to use pure SVG (not SVG within HTML) so that I can convert to a JPG later, thus scripting is out...

Any hints on how I can make the below work?

<image x="0" y="0" width="306" height="306" xlink:href="http://host.com/image.jpg?token=asdf&expiration=9384029&etc=etc"/>

Thanks!


回答1:


The solution is to replace the ampersands with the correct ascii code #38 and Not #63 (which is a question mark '?') as I had initially tried after mis-reading this question: using "?" in SVG href

Thanks to Stunti https://stackoverflow.com/users/54949/stunti

http://www.ascii.cl/htmlcodes.htm




回答2:


In all XML applications, including SVG, the following entities are valid without a custom DTD:

  • &amp; - &
  • &gt; - >
  • &lt; - <

In your case, this should work without resorting to ugly ASCII hacks:

<image xlink:href="http://foo.com/bar.jpg?token=asdf&amp;exp=9384&amp;etc=etc"/>


来源:https://stackoverflow.com/questions/6915058/ampersands-in-xlinkhref-attributes-of-svg-images

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!