溫馨提示×

溫馨提示×

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

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

Vue如何利用Blob下載原生二進(jìn)制數(shù)組文件

發(fā)布時(shí)間:2021-06-17 15:10:30 來源:億速云 閱讀:267 作者:小新 欄目:web開發(fā)

小編給大家分享一下Vue如何利用Blob下載原生二進(jìn)制數(shù)組文件,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

在服務(wù)端推送過來的二進(jìn)制數(shù)組(JSON格式),在前端要處理成JS原生數(shù)組以后才能做成Blob,有兩個(gè)地方要注意(詳細(xì)注釋),代碼如下:

Vue.prototype.$downloadFile = (filename, data) => {
 if (!data) return;
 let arr8 = Uint8Array.from(data); //?。?!注意1:應(yīng)根據(jù)數(shù)據(jù)的類型選擇適當(dāng)?shù)腏S原生數(shù)組類型進(jìn)行轉(zhuǎn)換,也就是說服務(wù)端推送的byte型數(shù)組還是int型數(shù)組等。
 //定義文件內(nèi)容,類型必須為Blob 否則createObjectURL會報(bào)錯(cuò)
 let blob = null;
 let type = 'application/octet-binary';
 if (typeof (window.Blob) == "function") {
  blob = new Blob([arr8], {//?。?!注意2:數(shù)組兩邊必須加上[]
   type: type
  });
 } else {
  let BlobBuilder = window.BlobBuilder || window.MozBlobBuilder || window.WebKitBlobBuilder || window.MSBlobBuilder;
  let bb = new BlobBuilder();
  bb.append([arr8]);
  blob = bb.getBlob(type);
 }
 let URL = window.URL || window.webkitURL;
 let bloburl = URL.createObjectURL(blob);
 let anchor = document.createElement("a");
 if ('download' in anchor) {
  anchor.style.visibility = "hidden";
  anchor.href = bloburl;
  anchor.download = filename;
  document.body.appendChild(anchor);
  let evt = document.createEvent("MouseEvents");
  evt.initEvent("click", true, true);
  anchor.dispatchEvent(evt);
  document.body.removeChild(anchor);
 } else if (navigator.msSaveBlob) {
  navigator.msSaveBlob(blob, filename);
 } else {
  location.href = bloburl;
 } //移除鏈接釋放資源
};

以上是“Vue如何利用Blob下載原生二進(jìn)制數(shù)組文件”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI