亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

javascript使用Blob對象實現的下載文件操作示例

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

本文實例講述了javascript使用Blob對象實現的下載文件操作。分享給大家供大家參考,具體如下:

Blob對象 前言 環境 操作 總結

Blob是一個類文件的不可變的原始數據對象,非javascript原生數據類型,File對象就是繼承自Blob對象,且在Blob的基礎上進行擴展,以便支持用戶系統上的文件。

前言

最近在做以post請求方式導出excel時,想到了可以使用Blob對象將后臺返回的輸出流以arraybuffer或blob的格式接收交給Blob處理,最后使用URL生成鏈接,供瀏覽器下載excel。

環境 vue2.x webpack3.x axios操作

import axios from ’axios’/*** 從服務器下載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(’瀏覽器不支持’) } })}/*** 發送http請求* @param {Object} settings api參數* @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 文件內容* @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標簽模擬下載* @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設置為arraybufferjavascript使用Blob對象實現的下載文件操作示例responseTyp設置成blobjavascript使用Blob對象實現的下載文件操作示例不設置responseType,出現亂碼javascript使用Blob對象實現的下載文件操作示例若引入mockjs,其攔截響應,重置了responseType,會出現亂碼javascript使用Blob對象實現的下載文件操作示例

總結 此下載excel只適用于post請求,get請求交給瀏覽器自行解析處理 responseType必須設置成arraybuffer或blob 下載excel時務必關閉mockjs之類的攔截響應的服務

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

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 久久国内精品自在自线400部o | 国产一级簧片 | 不卡视频在线播放 | 婷婷sese| 欧美一区二区三区不卡免费 | 97se亚洲综合在线韩国专区福利 | 色婷婷色综合激情国产日韩 | 亚洲第一综合色 | v视界成人影院在线视频 | 黄片毛片大全 | 国产毛片一区二区三区 | 视频在线观看rrr在线观看 | 日本高清视频www夜色资源 | 免费一级a毛片在线播放视 免费一级a毛片免费观看欧美大片 | 福利午夜国产网站在线不卡 | 国产1024精品视频专区免费 | 国产凹凸一区在线观看视频 | 三级黄色在线视频中文 | 国产精品免费视频一区一 | 国产精品v片在线观看不卡 国产精品v在线播放观看 | 国产亚洲精品久久久久久无 | 中国精品久久 | 999香蕉视频 | 国产免费福利视频 | 免费一级乱子伦片 | 亚洲伦理久久 | 欧美精品人爱c欧美精品 | 国产亚洲福利精品一区二区 | 中文字幕精品视频 | www小视频| 亚洲第五色综合网啪啪 | 激情综合婷婷 | 国产高清啪啪 | 青青青国产依人免费视频 | 青青操手机看 | 国产大学生露脸激情 | 成人99国产精品一级毛片 | 中文字幕日韩在线 | 国产精品亚洲第一区广西莫菁 | 国产高清精品一区 | 一级毛片在线播放 |