色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

javascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作示例

瀏覽:2日期:2023-11-03 11:30:13

本文實(shí)例講述了javascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作。分享給大家供大家參考,具體如下:

Blob對(duì)象 前言 環(huán)境 操作 總結(jié)

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。

環(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請(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) }}/*** 通過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)}// 下載exceldownloadExcel({ url: ’/default/excel/export’, responseType: ’arraybuffer’})

responseType設(shè)置為arraybufferjavascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作示例responseTyp設(shè)置成blobjavascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作示例不設(shè)置responseType,出現(xiàn)亂碼javascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作示例若引入mockjs,其攔截響應(yīng),重置了responseType,會(huì)出現(xiàn)亂碼javascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作示例

總結(jié) 此下載excel只適用于post請(qǐng)求,get請(qǐng)求交給瀏覽器自行解析處理 responseType必須設(shè)置成arraybuffer或blob 下載excel時(shí)務(wù)必關(guān)閉mockjs之類的攔截響應(yīng)的服務(wù)

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 美国三级大片 | 男女免费爽爽爽在线视频 | 国产成人毛片 | 久草最新在线 | 国产女王vk | 99久久成人国产精品免费 | 日本男人的天堂 | 亚洲一级毛片视频 | 在线色网址 | a在线观看欧美在线观看 | 国产日韩欧美在线一二三四 | 亚州精品一区二区三区 | 99久久免费看精品国产一区 | 亚洲精品99久久一区二区三区 | 九九草在线观看 | 99re热精品这里精品 | 日韩午夜视频在线观看 | 日本人的色道www免费一区 | 精品韩国主播福利视频在线观看一 | 黄网站色视频免费观看w | 国产成人最新毛片基地 | s8国产成人精品视频 | 国产成人精品永久免费视频 | 在线免费观看国产 | 国产在线视频网址 | 一级片aaa| 欧美一线高本道高清在线 | 精品国产三级在线观看 | 午夜精品视频在线观看美女 | 久久综合九色综合欧洲色 | 国产一级精品毛片 | 高清国产亚洲va精品 | 亚洲精品国产国语 | 国产高清久久 | 一级毛片真人免费观看 | 亚洲国产成a人v在线观看 | 337p粉嫩日本亚洲大胆艺术照 | 亚洲九九色 | 在线a亚洲视频播放在线观看 | 亚洲视频播放 | 在线欧洲成人免费视频 |