[求助贴] img 标签使用 src 属性无法显示 svg 图像

2023-12-21 22:14:09 +08:00
 yyhuan

我在 vue 前端项目中,需要显示一张图片,图片 url 地址从接口获取,我无法从数据分辨图像类型(可能是 jpg/png/svg )等

  1. 当我直接使用 img 标签,尝试使用 ur 显示这个图像时,svg 格式的图像无法正常显示
<img :src="url">
  1. 我直接在浏览器输入该 svg 图像的 url ,回车以后会直接下载该图片
  2. 我尝试使用 axios({ method: "get", url, responseType: "blob" }) 请求图像,可以成功获取,并通过以下方式将 svg 图像显示出来,请求如下:
axios({ method: "get", url: item.url, responseType: "blob" })
        .then((res: any) => {
            if (res?.hasError) {
                item.error = true;
                instance.delete(item.key);
                return;
            }

            let blob: any;
            if (item.mediaType === "IMAGE_SVG" || item.mediaType === "104" || res?.headers?.["content-type"] === "image/svg+xml") {
                blob = new Blob([res.data], { type: "image/svg+xml" });
            } else {
                blob = new Blob([res.data]);
            }

            el.setAttribute("src", URL.createObjectURL(blob));
            instance.caches.set(item.key, { status: 1, result: URL.createObjectURL(blob), responseData: res });

            // 动态获取大小
            if (res?.data?.size) {
                item.size = res?.data?.size;
            }

            item.error = false;
        })

请求返回的响应信息如下:

Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Cache-Control: max-age=0
Cache-Control: max-age=0
Connection: keep-alive
Content-Disposition: attachment; filename="笔记.svg"
Content-Type: application/x-download;charset=UTF-8
Date: Thu, 21 Dec 2023 14:08:30 GMT
Expires: 0
Keep-Alive: timeout=4
Pragma: no-cache
Proxy-Connection: keep-alive
Server: nginx/1.20.1
Transfer-Encoding: chunked
Vary: Origin
Vary: Access-Control-Request-Method
Vary: Access-Control-Request-Headers
X-Content-Type-Options: nosniff
X-Xss-Protection: 1; mode=block

想求助下大佬们,为什么直接使用 img 标签的 src 无法显示 svg 图像?

1091 次点击
所在节点    前端开发
5 条回复
yyhuan
2023-12-21 22:19:41 +08:00
额。。。难道需要设置 content-type: image/svg+xml ?
DarknessAF
2023-12-21 23:26:22 +08:00
是这个内容类型的问题,Content-Type: application/x-download; ,这种内容类型是浏览器会直接下载的,你可以先获取好 svg 文件的数据,然后用一个元素作为占位符,把获取到的 svg 数据直接插入占位符中,但是你需要注意下 vue 的 html 转码,推荐用下 v-html 。你也可以先 log 下获取到的 svg 数据是不是正常的。
yyhuan
2023-12-22 14:01:47 +08:00
@DarknessAF 感谢~ 但是我还有点疑问是,我通过 img 标签的 src 显示图像时,jpeg 、svg 等类型的图像返回的响应头信息是
Content-Disposition: attachment; filename="1_25.4k.jpeg"
Content-Type: application/x-download;charset=UTF-8
都是 application/x-download ,但 jpeg 的图片可以显示,svg 的图像不能显示,这是因为浏览器的内容嗅探机制么?
DarknessAF
2023-12-22 21:42:58 +08:00
> 这个可能是因为浏览器的没有兼容 svg 类型的数据流而已
> 内容类型 为 Content-Type: application/x-download; 时可能浏览器会直接用 src 读取对应的数据流。
> img 标签有还有一种用法是这样的

```
<img src="data:image/svg+xml;utf8,<svg>...</svg>">
```

这个网站有各种数据的转换示例,你可以看看。
https://base64.guru/converter/encode/image/svg
yyhuan
2023-12-26 20:38:25 +08:00
@DarknessAF 非常感谢大佬

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1002433

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX