您好,登錄后才能下訂單哦!
小編這次要給大家分享的是javascript如何使用Blob對(duì)象下載文件,文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
Blob對(duì)象
Blob是一個(gè)類文件的不可變的原始數(shù)據(jù)對(duì)象,非javascript原生數(shù)據(jù)類型,F(xiàn)ile對(duì)象就是繼承自Blob對(duì)象,且在Blob的基礎(chǔ)上進(jìn)行擴(kuò)展,以便支持用戶系統(tǒng)上的文件。
最近在做以post請(qǐng)求方式導(dǎo)出excel時(shí),想到了可以使用Blob對(duì)象將后臺(tái)返回的輸出流以arraybuffer或blob的格式接收交給Blob處理,最后使用URL生成鏈接,供瀏覽器下載excel。
import axios from 'axios' /** * 從服務(wù)器下載excel */ function downloadExcel (settings) { const defaultOptions = { responseType: 'arraybuffer' } Object.assign(settings.options, defaultOptions) requestToResponse(settings).then(res => { const filename = decodeURI(res.headers['content-disposition'].split('filename=')[1]) if ('download' in document.createElement('a')) { downloadFile(res.data, filename) } else { Message.error('瀏覽器不支持') } }) } /** * 發(fā)送http請(qǐng)求 * @param {Object} settings api參數(shù) * @returns reponse */ function requestToResponse (settings) { const defaultParams = { timeout: 45000, headers: { 'X-Requested-With': 'XMLHttpRequest', 'Content-Type': 'application/json' }, responseType: 'json', method: 'POST' } Object.assign(defaultParams, settings) return new Promise((resolve, reject) => { axios(defaultParams).then(res => { resolve(res) }).catch(err => { reject(err) }) }) } /** * blob下載(兼容IE) * @param {String} content 文件內(nèi)容 * @param {String} filename 文件名 */ function downloadFile (content, filename) { const blob = new Blob([content]) // IE if (window.navigator && window.navigator.msSaveOrOpenBlob) { window.navigator.msSaveOrOpenBlob(blob, filename) } else { imatateDownloadByA(window.URL.createObjectURL(blob), filename) } } /** * 通過(guò)a標(biāo)簽?zāi)M下載 * @param {String} href * @param {String} filename */ function imatateDownloadByA (href, filename) { const a = document.createElement('a') a.download = filename a.style.display = 'none' a.href = href document.body.appendChild(a) a.click() a.remove() window.URL.revokeObjectURL(href) } // 下載excel downloadExcel({ url: '/default/excel/export', responseType: 'arraybuffer' })
responseType設(shè)置為arraybuffer
responseTyp設(shè)置成blob
不設(shè)置responseType,出現(xiàn)亂碼
若引入mockjs,其攔截響應(yīng),重置了responseType,會(huì)出現(xiàn)亂碼
看完這篇關(guān)于javascript如何使用Blob對(duì)象下載文件的文章,如果覺(jué)得文章內(nèi)容寫得不錯(cuò)的話,可以把它分享出去給更多人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。