91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript如何使用Blob對象下載文件

發布時間:2020-08-03 09:28:36 來源:億速云 閱讀:207 作者:小豬 欄目:web開發

小編這次要給大家分享的是javascript如何使用Blob對象下載文件,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

Blob對象

  • 前言
  • 環境
  • 操作
  • 總結


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

前言

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

環境

  1. vue2.x
  2. webpack3.x
  3. 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)
}

// 下載excel
downloadExcel({
  url: '/default/excel/export',
  responseType: 'arraybuffer'
})

responseType設置為arraybuffer
javascript如何使用Blob對象下載文件
responseTyp設置成blob
javascript如何使用Blob對象下載文件
不設置responseType,出現亂碼
javascript如何使用Blob對象下載文件
若引入mockjs,其攔截響應,重置了responseType,會出現亂碼
javascript如何使用Blob對象下載文件

總結

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

看完這篇關于javascript如何使用Blob對象下載文件的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

台江县| 乐清市| 黄龙县| 镇江市| 廊坊市| 合江县| 潮安县| 徐闻县| 鹤壁市| 丽江市| 庆阳市| 拜泉县| 建瓯市| 洪泽县| 绥滨县| 武陟县| 凯里市| 盐边县| 防城港市| 旌德县| 宜都市| 凤凰县| 高青县| 宽甸| 沛县| 酉阳| 同德县| 昂仁县| 庄浪县| 娄底市| 基隆市| 慈利县| 弥渡县| 汉阴县| 宜兰市| 青海省| 同江市| 秦皇岛市| 甘南县| 西平县| 青河县|