中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

怎么在vue.js中利用axios實現(xiàn)一個下載功能-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)主要企業(yè)基礎(chǔ)官網(wǎng)建設(shè),電商平臺建設(shè),移動手機平臺,成都小程序開發(fā)等一系列專為中小企業(yè)定制網(wǎng)站設(shè)計產(chǎn)品體系;應(yīng)對中小企業(yè)在互聯(lián)網(wǎng)運營的各種問題,為中小企業(yè)在互聯(lián)網(wǎng)的運營中保駕護航。

Ajax無法下載文件的原因

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

response會交由瀏覽器處理

response內(nèi)容可以為二進制文件、字符串等

Ajax請求具有如下特點:

response會交由Javascript處理

response內(nèi)容僅可以為字符串

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

Axios攔截請求并實現(xiàn)下載

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

發(fā)送請求

獲得response

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

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

利用frame實現(xiàn)瀏覽器的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

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司的支持。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當前文章:怎么在vue.js中利用axios實現(xiàn)一個下載功能-創(chuàng)新互聯(lián)
文章源于:http://www.rwnh.cn/article48/ehdhp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、外貿(mào)建站自適應(yīng)網(wǎng)站、動態(tài)網(wǎng)站標簽優(yōu)化、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司
芜湖市| 温泉县| 罗江县| 仙游县| 丁青县| 昌宁县| 麻栗坡县| 南阳市| 黄石市| 巴林右旗| 遂宁市| 澄迈县| 公主岭市| 赫章县| 唐海县| 涟水县| 青浦区| 乌审旗| 莲花县| 纳雍县| 固原市| 黔东| 屏山县| 遂川县| 桑植县| 乡宁县| 石屏县| 郴州市| 靖西县| 永定县| 衡南县| 慈溪市| 大安市| 鲁甸县| 承德市| 泸西县| 津南区| 化隆| 盐源县| 浙江省| 江城|