亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

使用 JavaScript 創建并下載文件(模擬點擊)

發布時間:2020-08-26 13:36:03 來源:腳本之家 閱讀:142 作者:HyG 欄目:web開發

先上代碼

/**
 * 創建并下載文件
 * @param {String} fileName 文件名
 * @param {String} content 文件內容
 */
function createAndDownloadFile(fileName, content) {
 var aTag = document.createElement('a');
 var blob = new Blob([content]);
 aTag.download = fileName;
 aTag.href = URL.createObjectURL(blob);
 aTag.click();
 URL.revokeObjectURL(blob);
}

很簡單對吧,直接調用這個方法,傳入文件名和文件內容,程序新建 a 標簽,新建 Blob 對象,將文件名賦給 a 標簽,同時將 Blob 對象作為 Url 也賦給 a 標簽,模擬點擊事件,自動下載成功,最后再回收內存。下面我們來看看具體是怎么操作的。

使用 JavaScript 創建并下載文件(模擬點擊)

Blob 對象

Blob 對象是一個字節序列。擁有 size 和 type 等屬性。

擁有 2 個只讀狀態 OPEND 和 CLOSED

Blob 對象屬于 JavaScript Web APIs 中的 File API 規定的部分,可以參考 W3C 文檔中的 The Blob Interface and Binary Data

再回來看看我們的代碼里是這么寫的,使用了 Blob 的構造函數:

var blob = new Blob([content]);

使用方括號的原因是,其構造函數的參數為以下4中:

  • ArrayBuffer [TypedArrays] elements.
  • ArrayBufferView [TypedArrays] elements.
  • Blob elements.
  • DOMString [WebIDL] elements.

所謂 ArrayBuffer 是一種用于呈現通用、固定長度的二進制數據的類型。詳情可以參考 ArrayBuffer -MDN 以及 ECMAScript2015 標準中的 ArrayBuffer。

Blob URLs

Blob URLs 被創建或注銷是使用 URL 對象上的方法。這個 URL 對象被掛在 Window (HTML) 對象下,或者 WorkerGlobalScope (Web Workers)對象下。

擁有以下靜態方法 createObjectURL 和 revokeObjectURL,用于創建一個 blob 對象的 url 和注銷這個 blob url。

詳情可查看 關于創建和注銷 Blob URL 的 W3C 標準文檔

模擬 click

element.click();

在 W3C 中很早就有這個規范,不需要寫繁瑣的模擬事件觸發的代碼。

小結

目前我將這個技術使用在 天貓雙十一技術和UED慶功會 的搖火箭大屏游戲中。最后的游戲結果排名,在請求了接口后,在前端直接生成并下載到了本地,作為記錄保存。主要也是因為服務端暫時沒有提供這個一張表去記錄游戲結果,于是采用了前端記錄的解決方案。

大家當時都玩的好開心啊,😁。你們的甘其食和全家卡的名單就是這樣生成的!

向AI問一下細節

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

AI

鲁山县| 大港区| 盐城市| 胶州市| 桦甸市| 舟曲县| 汝南县| 宁城县| 麻栗坡县| 陇川县| 宝清县| 易门县| 邹城市| 夏津县| 宁强县| 资讯| 楚雄市| 昌黎县| 本溪市| 来宾市| 翁源县| 海口市| 繁昌县| 福鼎市| 虹口区| 张家川| 渑池县| 光泽县| 瑞安市| 井陉县| 江川县| 龙游县| 六盘水市| 翁源县| 怀仁县| 葵青区| 许昌县| 永平县| 德惠市| 长沙县| 达孜县|