国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Javascript前端下載后臺傳來的文件流代碼實例

瀏覽:62日期:2023-10-18 08:13:32

前臺請求數據:

url: ’/app/downloadApp’, method: ’get’, responseType: ’blob’, params: data

設置接收參數格式為responseType: ‘blob’,

downloadFile(res, fileName) { if (!res) { return } if (window.navigator.msSaveBlob) { // IE以及IE內核的瀏覽器 try { window.navigator.msSaveBlob(res, fileName) // res為接口返回數據,這里請求的時候已經處理了,如果沒處理需要在此之前自行處理var data = new Blob([res.data]) 注意這里需要是數組形式的,fileName就是下載之后的文件名 // window.navigator.msSaveOrOpenBlob(res, fileName); //此方法類似上面的方法,區別可自行百度 } catch (e) { console.log(e) } } else { let url = window.URL.createObjectURL(new Blob([res])) let link = document.createElement(’a’) link.style.display = ’none’ link.href = url link.setAttribute(’download’, fileName)// 文件名 document.body.appendChild(link) link.click() document.body.removeChild(link) // 下載完成移除元素 window.URL.revokeObjectURL(url) // 釋放掉blob對象 } }, download(){ var data = { appId:this.appId } downloadAppAjax(data).then(res => { const filename = decodeURI(res.headers[’content-disposition’].split(’;’)[1].split(’=’)[1]); console.log(filename) this.downloadFile(res.data,filename) }) }

這里的downloadAppAjax調用后臺接口,請求數據,獲取后臺返回的數據沒有文件名,最后發現在header Content-Disposition屬性里 attachment;filename=app.jpg

所以我們要實現下載自動重命名就需要拿出filename,這里我們使用decodeURI對Content-Disposition屬性值進行解碼,拿到filename:

decodeURI(res.headers[’content-disposition’].split(’;’)[1].split(’=’)[1]);

拿到文件流和文件名后 接收文件流并創建地址

let url =window.URL.createObjectURL(new Blob([res]))

接著利用a標簽進行下載即可。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 丽江市| 吐鲁番市| 潜山县| 裕民县| 平顶山市| 宁强县| 鄄城县| 武隆县| 准格尔旗| 忻州市| 大方县| 沂源县| 兴城市| 宁河县| 南雄市| 辽宁省| 通渭县| 名山县| 大田县| 贺兰县| 虹口区| 五台县| 武穴市| 邢台市| 滨海县| 珲春市| 来凤县| 衡南县| 五常市| 普兰店市| 和硕县| 米泉市| 利津县| 太仓市| 纳雍县| 章丘市| 通海县| 嘉义市| 丘北县| 攀枝花市| 莲花县|