javascript使用Blob對象實現(xiàn)的下載文件操作示例
本文實例講述了javascript使用Blob對象實現(xiàn)的下載文件操作。分享給大家供大家參考,具體如下:
Blob對象
Blob是一個類文件的不可變的原始數(shù)據(jù)對象,非javascript原生數(shù)據(jù)類型,F(xiàn)ile對象就是繼承自Blob對象,且在Blob的基礎(chǔ)上進(jìn)行擴(kuò)展,以便支持用戶系統(tǒng)上的文件。
前言
最近在做以post請求方式導(dǎo)出excel時,想到了可以使用Blob對象將后臺返回的輸出流以arraybuffer或blob的格式接收交給Blob處理,最后使用URL生成鏈接,供瀏覽器下載excel。
環(huán)境
- vue2.x
- webpack3.x
- axios
操作
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請求
* @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)
}
}
/**
* 通過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,會出現(xiàn)亂碼

總結(jié)
- 此下載excel只適用于post請求,get請求交給瀏覽器自行解析處理
- responseType必須設(shè)置成arraybuffer或blob
- 下載excel時務(wù)必關(guān)閉mockjs之類的攔截響應(yīng)的服務(wù)
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
javascript實現(xiàn)將文件保存到本地方法匯總
本文給大家匯總介紹了3中使用javascript實現(xiàn)將文件保存到本地的方法,非常的簡單實用,有需要的小伙伴可以參考下。2015-07-07
javascript中的類,繼承,構(gòu)造函數(shù)詳解
這篇文章主要為大家詳細(xì)介紹了javascript中的類,繼承,構(gòu)造函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-02-02
js插件設(shè)置innerHTML時在IE8下提示“未知運行時錯誤”解決方法
這篇文章主要介紹了js插件設(shè)置innerHTML時在IE8下提示“未知運行時錯誤”解決方法,較為詳細(xì)的分析了錯誤的原因及對應(yīng)的解決方法,需要的朋友可以參考下2015-04-04

