vue附件下載無法打開的問題及解決
更新時間:2024年07月27日 10:30:21 作者:王紅珠
這篇文章主要介紹了vue附件下載無法打開的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
vue附件下載無法打開
描述
最近做了一個excel導出功能,在瀏覽器地址欄直接請求接口可以正常下載,但在vue項目里請求接口返回值為一堆亂碼
如下圖:

代碼如下:

查閱資料后
知道需要將后端java返回的文件流處理為blob,并下載
代碼如下:

現(xiàn)在文件可以導出了,但是導出的文件無法查看
如下圖:

最終解決方案為在請求中添加 responseType: 'blob'
代碼如下:
const params = {
siteId: this.siteId,
beginDate: this.dateValue[0],
endDate: this.dateValue[1]
}
axios.get('/ui/sacstatistics/getStatisticsExcel', { params, responseType: 'blob' }).then((res) => {
const data = res.data
let blob = new Blob([data], {
type: 'application/vnd.ms-excel'
})
let url = window.URL.createObjectURL(blob)
let a = document.createElement('a')
a.href = url
a.download = '網站內容更新統(tǒng)計.xlsx' // 自定義文件名稱
a.click()
})
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
解決vue項目,npm run build后,報路徑錯的問題
這篇文章主要介紹了解決vue項目,npm run build后,報路徑錯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08

