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,到这里为止就解决问题了。