怎么在vue.js中利用axios實現一個下載功能?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
Ajax無法下載文件的原因
瀏覽器的GET(frame、a)和POST(form)請求具有如下特點:
response會交由瀏覽器處理
response內容可以為二進制文件、字符串等
Ajax請求具有如下特點:
response會交由Javascript處理
response內容僅可以為字符串
因此,Ajax本身無法觸發(fā)瀏覽器的下載功能。
Axios攔截請求并實現下載
為了下載文件,我們通常會采用以下步驟:
發(fā)送請求
獲得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
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯成都網站設計公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯成都網站設計公司的支持。
另外有需要云服務器可以了解下創(chuàng)新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、網站設計器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
當前文章:怎么在vue.js中利用axios實現一個下載功能-創(chuàng)新互聯
文章源于:http://chinadenli.net/article48/ehdhp.html
成都網站建設公司_創(chuàng)新互聯,為您提供關鍵詞優(yōu)化、外貿建站、自適應網站、動態(tài)網站、標簽優(yōu)化、靜態(tài)網站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯