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

溫馨提示×

溫馨提示×

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

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

Vue如何利用Blob下載原生二進制數組文件

發布時間:2021-06-17 15:10:30 來源:億速云 閱讀:269 作者:小新 欄目:web開發

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

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

Vue.prototype.$downloadFile = (filename, data) => {
 if (!data) return;
 let arr8 = Uint8Array.from(data); //!!!注意1:應根據數據的類型選擇適當的JS原生數組類型進行轉換,也就是說服務端推送的byte型數組還是int型數組等。
 //定義文件內容,類型必須為Blob 否則createObjectURL會報錯
 let blob = null;
 let type = 'application/octet-binary';
 if (typeof (window.Blob) == "function") {
  blob = new Blob([arr8], {//!!!注意2:數組兩邊必須加上[]
   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下載原生二進制數組文件”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

抚顺县| 昌平区| 巨鹿县| 二连浩特市| 德保县| 建水县| 开平市| 伊春市| 乌兰县| 仪陇县| 东城区| 廉江市| 子洲县| 安达市| 京山县| 桂林市| 广元市| 健康| 西乌| 沙河市| 通辽市| 凤台县| 六安市| 汤原县| 双城市| 新沂市| 宁安市| 布尔津县| 大关县| 庄浪县| 永德县| 唐河县| 上杭县| 同德县| 文昌市| 大宁县| 汕尾市| 广宗县| 虹口区| 广水市| 清涧县|