猿站网:导出文件时,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,到这里为止就解决问题了。

建站知识

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

2022-5-19 21:10:00

建站知识

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

2022-5-19 21:20:09

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