图片路径前缀有blob?图片渲染不出来?

知识储备

  • 什么是Blob? 一种Javascript对象类型

写bug

你们遇见过这种图片路径咩

就很奇葩吧哈哈因为我图片渲染不出来~
在这里插入图片描述
好像我保存之后就有这个 数据库也是有这个前缀

我的代码是这样的:

handleAvatarSuccess(response, file, fileList) {
   const url = "http://localhost:7001" + file.response.url;
   console.log(url, "------------------------");
   this.image = URL.createObjectURL(file.raw);

后来我尝试了一下重新发布一个动态:图片显示出来了,诡异吧

在这里插入图片描述
更诡异的是,刷新之后又没了~过山车的心情!!!

在这里插入图片描述

解决

然后我就去看了一堆推文然后再看看自己找之前写的项目:

this.image = URL.createObjectURL(file.raw);

换成

this.image = url;

就成功了

原因

问了下AI原因:

如果数据库的图片地址前缀带有blob://,那么可能是因为在上传图片时,使用了Blob URL来表示图片。在JavaScript中,Blob URL是通过URL.createObjectURL(blob)方法创建的,其格式为blob://加上一个由浏览器自动生成的32位十六进制的字符串。用Blob URL表示的图片是存储在浏览器的内存中,而不是存储在硬盘上,所以当你在另一个页面中打开这个URL时,就无法访问该图片。

如果需要在其他页面中打开这些图片,可以考虑在上传图片时,保存其二进制数据到数据库中,然后在其他页面中使用这些二进制数据来构造图片。具体实现可以参考base64编码方式或者其他方式来实现。

参考

vue中接受后台传过来的图片文件流blob前端进行展示实现方法

vue异步获取图片流文件进行图片显示

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿珊和她的猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值