使用 JavaScript 創(chuàng)建并下載文件(模擬點(diǎn)擊)
先上代碼
/**
* 創(chuàng)建并下載文件
* @param {String} fileName 文件名
* @param {String} content 文件內(nèi)容
*/
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);
}
很簡單對吧,直接調(diào)用這個(gè)方法,傳入文件名和文件內(nèi)容,程序新建 a 標(biāo)簽,新建 Blob 對象,將文件名賦給 a 標(biāo)簽,同時(shí)將 Blob 對象作為 Url 也賦給 a 標(biāo)簽,模擬點(diǎn)擊事件,自動(dòng)下載成功,最后再回收內(nèi)存。下面我們來看看具體是怎么操作的。

Blob 對象
Blob 對象是一個(gè)字節(jié)序列。擁有 size 和 type 等屬性。
擁有 2 個(gè)只讀狀態(tài) OPEND 和 CLOSED。
Blob 對象屬于 JavaScript Web APIs 中的 File API 規(guī)定的部分,可以參考 W3C 文檔中的 The Blob Interface and Binary Data
再回來看看我們的代碼里是這么寫的,使用了 Blob 的構(gòu)造函數(shù):
var blob = new Blob([content]);
使用方括號的原因是,其構(gòu)造函數(shù)的參數(shù)為以下4中:
- ArrayBuffer [TypedArrays] elements.
- ArrayBufferView [TypedArrays] elements.
- Blob elements.
- DOMString [WebIDL] elements.
所謂 ArrayBuffer 是一種用于呈現(xiàn)通用、固定長度的二進(jìn)制數(shù)據(jù)的類型。詳情可以參考 ArrayBuffer -MDN 以及 ECMAScript2015 標(biāo)準(zhǔn)中的 ArrayBuffer。
Blob URLs
Blob URLs 被創(chuàng)建或注銷是使用 URL 對象上的方法。這個(gè) URL 對象被掛在 Window (HTML) 對象下,或者 WorkerGlobalScope (Web Workers)對象下。
擁有以下靜態(tài)方法 createObjectURL 和 revokeObjectURL,用于創(chuàng)建一個(gè) blob 對象的 url 和注銷這個(gè) blob url。
詳情可查看 關(guān)于創(chuàng)建和注銷 Blob URL 的 W3C 標(biāo)準(zhǔn)文檔
模擬 click
element.click();
在 W3C 中很早就有這個(gè)規(guī)范,不需要寫繁瑣的模擬事件觸發(fā)的代碼。
小結(jié)
目前我將這個(gè)技術(shù)使用在 天貓雙十一技術(shù)和UED慶功會(huì) 的搖火箭大屏游戲中。最后的游戲結(jié)果排名,在請求了接口后,在前端直接生成并下載到了本地,作為記錄保存。主要也是因?yàn)榉?wù)端暫時(shí)沒有提供這個(gè)一張表去記錄游戲結(jié)果,于是采用了前端記錄的解決方案。
大家當(dāng)時(shí)都玩的好開心啊,😁。你們的甘其食和全家卡的名單就是這樣生成的!
相關(guān)文章
JavaScript判斷訪問的來源是手機(jī)還是電腦,用的哪種瀏覽器
這篇文章主要介紹了使用JavaScript判斷訪問的來源是手機(jī)還是電腦,用的哪種瀏覽器。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12
JavaScript實(shí)現(xiàn)計(jì)算器的四則運(yùn)算功能
這篇文章主要為大家介紹了如何通過JavaScript實(shí)現(xiàn)計(jì)算器的四則運(yùn)算功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起動(dòng)手試試2022-02-02
BootStrap Validator 根據(jù)條件在JS中添加或移除校驗(yàn)操作
這篇文章主要介紹了BootStrap Validator 根據(jù)條件在JS中添加或移除校驗(yàn)的相關(guān)資料,需要的朋友可以參考下2017-10-10
BootStrap表單驗(yàn)證 FormValidation 調(diào)整反饋圖標(biāo)位置的實(shí)例代碼
這篇文章主要介紹了BootStrap表單驗(yàn)證 FormValidation 調(diào)整反饋圖標(biāo)位置的實(shí)例代碼,需要的朋友可以參考下2017-05-05
十個(gè)利用JavaScript實(shí)現(xiàn)的愛心動(dòng)畫特效
情人節(jié)將至,程序員證明自己不是直男的時(shí)候到啦!小編為大家準(zhǔn)備了十個(gè)通過JavaScript實(shí)現(xiàn)的愛心動(dòng)畫特效,快學(xué)起來,到時(shí)候給女朋友一個(gè)驚喜吧2022-02-02
js彈出層包含flash 不能關(guān)閉隱藏的2種處理方法
js彈出層包含flash 不能關(guān)閉隱藏的2種處理方法,需要的朋友可以參考一下2013-06-06
微信小程序?qū)崿F(xiàn)的日期午別醫(yī)生排班表功能示例
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的日期午別醫(yī)生排班表功能,結(jié)合實(shí)例形式分析了微信小程序?qū)崿F(xiàn)基于日期時(shí)間、針對上午、下午、凌晨、夜間等時(shí)段的排班功能相關(guān)操作技巧,需要的朋友可以參考下2019-01-01

