用JS在瀏覽器中創(chuàng)建下載文件
但受限于瀏覽器,很多情況下我們都只能給出個(gè)鏈接,讓用戶點(diǎn)擊打開-》另存為。如下面這個(gè)鏈接:
<a href=”file.js”>file.js</a>
用戶點(diǎn)擊這個(gè)鏈接的時(shí)候,瀏覽器會(huì)打開并顯示鏈接指向的文件內(nèi)容,顯然,這并沒有實(shí)現(xiàn)我們的需求。HTML5中給a標(biāo)簽增加了一個(gè)download屬性,只要有這個(gè)屬性,點(diǎn)擊這個(gè)鏈接時(shí)瀏覽器就不在打開鏈接指向的文件,而是改為下載(目前只有chrome、firefox和opera支持)。
下載時(shí)會(huì)直接使用鏈接的名字來作為文件名,但是是可以改的,只要給download加上想要的文件名即可,如:download=“not-a-file.js”。
但是這樣還不夠,以上的方法只適合用在文件是在服務(wù)器上的情況。如果在瀏覽器端js生成的內(nèi)容,想讓瀏覽器進(jìn)行下載要如何辦到呢?
其實(shí)還是有辦法辦到的,相信很多人都多少聽過了DataURI這個(gè)詞,比較常見的就是圖片的src,如:
<img src=”data:image/gif;base64,R0lGOXXXXX">
DataURI的解釋可以移步這里,本人就不在解釋了。
那么,現(xiàn)在要將js生成的內(nèi)容進(jìn)行下載就有法可依了。封裝成一個(gè)方法如下:
function downloadFile(aLink, fileName, content){
aLink.download = fileName;
aLink.href = "data:text/plain," + content;
}
調(diào)用downloadFile之后,用戶點(diǎn)擊鏈接,就能觸發(fā)瀏覽器下載。
但是,還不夠,上面的辦法有兩個(gè)硬傷,會(huì)導(dǎo)致流失很多懶人美眉:
下載的文件類型限制死了,美眉要下載處理后的果照怎么辦?
下載還要再點(diǎn)擊一下,太麻煩啦。
要解決文件類型的問題,可以用瀏覽器的新API(URL.createObjectURL)來解決問題,URL.createObjectURL通常都是用來創(chuàng)建圖片的DataURI用來顯示圖片,這里用來下載文件,讓瀏覽器來幫我們設(shè)定好文件類型。
URL.createObjectURL的參數(shù)是File對象或者Blob對象,F(xiàn)ile對象也就是通過input[type=file]選擇的文件,Blob對象是二進(jìn)制大對象,詳細(xì)說明可參考這里。
現(xiàn)在,我們只要用content創(chuàng)建一個(gè)ObjectURL并賦值給aLink即可解決文件類型的限制問題。
文件的自動(dòng)下載也挺好辦,自己構(gòu)建一個(gè)UI點(diǎn)擊事件,再自動(dòng)觸發(fā)下,就能實(shí)現(xiàn)自動(dòng)下載啦。
現(xiàn)在來看看最終代碼:
function downloadFile(fileName, content){
var aLink = document.createElement('a');
var blob = new Blob([content]);
var evt = document.createEvent("HTMLEvents");
evt.initEvent("click", false, false);//initEvent 不加后兩個(gè)參數(shù)在FF下會(huì)報(bào)錯(cuò), 感謝 Barret Lee 的反饋
aLink.download = fileName;
aLink.href = URL.createObjectURL(blob);
aLink.dispatchEvent(evt);
}
現(xiàn)在,只要一調(diào)用downloadFile,文件就自動(dòng)下載了,是不是很爽咧,^_^。
注:目前(2014-01)Blob和URL.createObjectURL在標(biāo)準(zhǔn)瀏覽器里面都不再需要加私有前綴,可以放心使用啦啦啦~~如果你不放心,可以查查Can I Use。
相關(guān)文章
JS基于構(gòu)造函數(shù)實(shí)現(xiàn)的菜單滑動(dòng)顯隱效果【測試可用】
這篇文章主要介紹了JS基于構(gòu)造函數(shù)實(shí)現(xiàn)的菜單滑動(dòng)顯隱效果,可實(shí)現(xiàn)基本的菜單折疊與展開功能,涉及javascript響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁面元素的相關(guān)技巧,需要的朋友可以參考下2016-06-06uniapp上傳圖片和上傳視頻的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于uniapp上傳圖片和上傳視頻的實(shí)現(xiàn)方法,文中還介紹了上傳文件的方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01uniapp實(shí)現(xiàn)全局設(shè)置字體大小(小中大的字體切換)
隨著UniApp的流行,越來越多的開發(fā)者選擇使用它來構(gòu)建跨平臺應(yīng)用程序,下面這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)全局設(shè)置字體大小(小中大的字體切換)的相關(guān)資料,需要的朋友可以參考下2023-06-06js 轉(zhuǎn)json格式的字符串為對象或數(shù)組(前后臺)的方法
下面小編就為大家?guī)硪黄猨s 轉(zhuǎn)json格式的字符串為對象或數(shù)組(前后臺)的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11echarts多條折線圖動(dòng)態(tài)分層的實(shí)現(xiàn)方法
這篇文章主要介紹了echarts多條折線圖動(dòng)態(tài)分層的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05JS實(shí)現(xiàn)時(shí)間軸自動(dòng)播放
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)時(shí)間軸自動(dòng)播放,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08html的DOM中document對象images集合用法實(shí)例
這篇文章主要介紹了html的DOM中document對象images集合用法,實(shí)例分析了images集合的語法與使用技巧,需要的朋友可以參考下2015-01-01