猿站网:导出文件时,responseType设置为arraybuffer,如果导出出错,后台返回错误信息应该怎么办?

1、恒定求出的情形:(采用axios推送允诺)后端回到十进制文档

api文档

async download(params) {
  return await  $axios.$post(`url`,params,{ responseType: arraybuffer})
  },

初始化api

let formData = new FormData();

formData.append(file,file);//传文档

this.$api.download(formData).then(res=>{
 
const data = new Blob([res],{type:application/vnd.ms-excel})
 
const url = URL.createObjectURL(data)
 
const a = document.createElement(a)
 
a.href = url
 
a.download = table.xls
 
a.click()
// 释放出来那个临时性的第一类objectUrl
URL.revokeObjectURL(url)
 
}

2、假如重要信息量过多则后端回到原始数据

虽然允诺的这时候增设了responseType:’arraybuffer’,回到的是报文,要获得json重要信息须要展开切换:

let enc = new TextDecoder(utf-8)
let data = JSON.parse(enc.decode(new Uint8Array(res.data)))

严重错误提示重要信息为:(该处精简了)

$axios.onError(error => {
  let enc = new TextDecoder(utf-8)
  let blob = JSON.parse(enc.decode(new Uint8Array(error.response.data)))
  Vue.prototype.$message.error(blob.data);
})

ok,到这里为止就解决问题了。

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:微信小程序target和currentTarget的区别

2022-5-19 21:10:00

建站知识

小知识:在electron-vue中配置跨域代理

2022-5-19 21:20:09

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索