包含在 HTML 中的带有“img”标签的 SVG 可以链接到带有“image”标签的外部图像吗?

Posted

技术标签:

【中文标题】包含在 HTML 中的带有“img”标签的 SVG 可以链接到带有“image”标签的外部图像吗?【英文标题】:Can an SVG included in HTML with an "img" tag have a link to an external image with the "image" tag? 【发布时间】:2012-07-06 08:50:31 【问题描述】:

我在服务器的同一位置有以下文件 image.svg 以及文件 bitmap.png:

<?xml version="1.0" ?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" 
  "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg   version="1.1"
     xmlns="http://www.w3.org/2000/svg"
     xmlns:xlink="http://www.w3.org/1999/xlink">
  <image x="0" y="0"  
         xlink:href="bitmap.png" />
</svg>

当我直接进入图像文件时,它包含了 bitmap.png 图像。

当我在带有&lt;object data="image.svg"&gt;&lt;/object&gt; 标签的网页中包含图片时,会加载 bitmap.png 文件。

当我将图片包含在带有&lt;img src="image.svg" /&gt; 标签的网页中时,bitmap.png 不会 加载。

什么给了?

【问题讨论】:

【参考方案1】:

svg 本身是有效的。

当通过 引用 svg 时,某些浏览器不允许外部引用。要使其正常工作,您可以将 png 转换为数据 URI 并将其放在那里,请参阅例如 this answer 了解如何执行此操作。

【讨论】:

以上是关于包含在 HTML 中的带有“img”标签的 SVG 可以链接到带有“image”标签的外部图像吗?的主要内容,如果未能解决你的问题,请参考以下文章

html没有在img标签中显示svg文件

HTML5 中的 SVG 标记可以省略自闭标签吗?

使用 onclick 使 svg 图像对象可点击,避免绝对定位

在 <img> 标签中使用时,嵌入在 SVG 中的动态 CSS 不起作用

如何读取和更改使用 html 或 xhtml 中的图像标签包含的 svg 文件中的元素? [复制]

HTML 带有img标记和JavaScript的SVG图像,用于不支持的浏览器。