TypeError: Failed to execute ‘createObjectURL‘ on ‘URL‘: Overload resolution failed

//request.js
service.interceptors.response.use(
  (response) => {
    const res = response.data
    
    // 下载文件
    if (!res.code) {
      return response
    }
    ...
  },
  (error) => {
  	...
  }
export function downloadQrcode(params) {
  return request({
    url: '/multiplayer-draw/download-qrcode',
    method: 'get',
    // headers: { 'Content-Type': 'image/png; charset=UTF-8' }, 
    responseType: 'blob',		// response类型
    params
  })
}
downloadQrcode({id: this.id}).then(res => {
  console.log(res,'res'); 
  var a = document.createElement('a')
  document.body.appendChild(a)
  a.style = 'display: none'
  let url = window.URL.createObjectURL(res); 
  a.href =  url
  a.download = '二维码.png'
  a.click()
  a.remove()
  window.URL.revokeObjectURL(url) // 释放url
})

发现报错:
在这里插入图片描述
同时,发现接口是有返回值的:
在这里插入图片描述

再看打印的res:
在这里插入图片描述发现打印的res并不是最后我们需要的Blob值,我们需要的是Blob类型的值,发现正是res.data(但是从浏览器控制台并不能看出data),所以应该修改request.js为:

const res = response.data

 // 下载文件
 if (!res.code) {
   return response.data //等同于 return res
 }

此时发现打印的res为:
在这里插入图片描述
也没有“TypeError: Failed to execute ‘createObjectURL’ on ‘URL’: Overload resolution failed”这个报错了,成功下载了图片。

还有第二种方法:创建一个Blob

downloadQrcode({id: this.id}).then(res => {
   console.log(res,'res');
   var a = document.createElement('a')
   document.body.appendChild(a)
   a.style = 'display: none'
   //增加了下面三行
   let blob = new Blob([res], {
     type: "image/png",
   }); 
   let url = window.URL.createObjectURL(blob); 
   a.href =  url
   a.download = '二维码'
   a.click()
   a.remove()
   window.URL.revokeObjectURL(url) // 释放url
 })

发现打印的res没变
在这里插入图片描述
但是也没有出现“TypeError: Failed to execute ‘createObjectURL’ on ‘URL’: Overload resolution failed”报错,而且a.download = '二维码.png’变成了a.download = ‘二维码’,也成功下载了图片。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用、和的内容,你遇到了一个错误:Uncaught TypeError: Failed to execute 'createObjectURL' on 'URL': Overload resolution failed. 这个错误通常是由于Chrome更新后不再支持之前的createObjectURL用法所引起的。 根据引用中的解释,你可以尝试修改代码,使用新的方式来创建URL。你可以将blob数据存入数组,然后使用新的Blob对象和URL.createObjectURL方法来创建URL。具体来说,你可以这样修改代码: ```javascript let binaryData = []; binaryData.push(blob); link.href = window.URL.createObjectURL(new Blob(binaryData)); ``` 这样修改后,应该能够解决createObjectURL方法报错的问题。希望对你有帮助!123 #### 引用[.reference_title] - *1* *2* [TypeError: Failed to executecreateObjectURL‘ on ‘URL‘: Overload resolution failed](https://blog.csdn.net/qq_46302247/article/details/130011494)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *3* [Failed to executecreateObjectURL‘ on ‘URL‘ Overload resolution failed](https://blog.csdn.net/fwdwqdwq/article/details/123345822)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值