溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在vue.js中利用axios實現一個下載功能

發布時間:2021-03-29 16:16:10 來源:億速云 閱讀:183 作者:Leah 欄目:web開發

怎么在vue.js中利用axios實現一個下載功能?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

Ajax無法下載文件的原因

瀏覽器的GET(frame、a)和POST(form)請求具有如下特點:

response會交由瀏覽器處理

response內容可以為二進制文件、字符串等

Ajax請求具有如下特點:

response會交由Javascript處理

response內容僅可以為字符串

因此,Ajax本身無法觸發瀏覽器的下載功能。

Axios攔截請求并實現下載

為了下載文件,我們通常會采用以下步驟:

發送請求

獲得response

通過response判斷返回是否為文件

如果是文件則在頁面中插入frame

利用frame實現瀏覽器的get下載

我們可以為axios添加一個攔截器:

import axios from 'axios'
// download url
const downloadUrl = url => {
 let iframe = document.createElement('iframe')
 iframe.style.display = 'none'
 iframe.src = url
 iframe.onload = function () {
 document.body.removeChild(iframe)
 }
 document.body.appendChild(iframe)
}
// Add a response interceptor
axios.interceptors.response.use(c=> {
 // 處理excel文件
 if (res.headers && (res.headers['content-type'] === 'application/x-msdownload' || res.headers['content-type'] === 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')) {
 downloadUrl(res.request.responseURL)
 
 <span > res.data='';
 res.headers['content-type'] = 'text/json'
 return res;</span>
 }
 ...
 return res;
}, error => {
 <span >// Do something with response error
 return Promise.reject(error.response.data || error.message)</span>
})
export default axios

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女