用JS在瀏覽器中創(chuàng)建下載文件
但受限于瀏覽器,很多情況下我們都只能給出個鏈接,讓用戶點擊打開-》另存為。如下面這個鏈接:
<a href=”file.js”>file.js</a>
用戶點擊這個鏈接的時候,瀏覽器會打開并顯示鏈接指向的文件內(nèi)容,顯然,這并沒有實現(xiàn)我們的需求。HTML5中給a標簽增加了一個download屬性,只要有這個屬性,點擊這個鏈接時瀏覽器就不在打開鏈接指向的文件,而是改為下載(目前只有chrome、firefox和opera支持)。

下載時會直接使用鏈接的名字來作為文件名,但是是可以改的,只要給download加上想要的文件名即可,如:download=“not-a-file.js”。

但是這樣還不夠,以上的方法只適合用在文件是在服務器上的情況。如果在瀏覽器端js生成的內(nèi)容,想讓瀏覽器進行下載要如何辦到呢?
其實還是有辦法辦到的,相信很多人都多少聽過了DataURI這個詞,比較常見的就是圖片的src,如:
<img src=”data:image/gif;base64,R0lGOXXXXX">
DataURI的解釋可以移步這里,本人就不在解釋了。
那么,現(xiàn)在要將js生成的內(nèi)容進行下載就有法可依了。封裝成一個方法如下:
function downloadFile(aLink, fileName, content){
aLink.download = fileName;
aLink.href = "data:text/plain," + content;
}
調(diào)用downloadFile之后,用戶點擊鏈接,就能觸發(fā)瀏覽器下載。
但是,還不夠,上面的辦法有兩個硬傷,會導致流失很多懶人美眉:
下載的文件類型限制死了,美眉要下載處理后的果照怎么辦?
下載還要再點擊一下,太麻煩啦。
要解決文件類型的問題,可以用瀏覽器的新API(URL.createObjectURL)來解決問題,URL.createObjectURL通常都是用來創(chuàng)建圖片的DataURI用來顯示圖片,這里用來下載文件,讓瀏覽器來幫我們設(shè)定好文件類型。
URL.createObjectURL的參數(shù)是File對象或者Blob對象,F(xiàn)ile對象也就是通過input[type=file]選擇的文件,Blob對象是二進制大對象,詳細說明可參考這里。
現(xiàn)在,我們只要用content創(chuàng)建一個ObjectURL并賦值給aLink即可解決文件類型的限制問題。
文件的自動下載也挺好辦,自己構(gòu)建一個UI點擊事件,再自動觸發(fā)下,就能實現(xiàn)自動下載啦。
現(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 不加后兩個參數(shù)在FF下會報錯, 感謝 Barret Lee 的反饋
aLink.download = fileName;
aLink.href = URL.createObjectURL(blob);
aLink.dispatchEvent(evt);
}
現(xiàn)在,只要一調(diào)用downloadFile,文件就自動下載了,是不是很爽咧,^_^。
注:目前(2014-01)Blob和URL.createObjectURL在標準瀏覽器里面都不再需要加私有前綴,可以放心使用啦啦啦~~如果你不放心,可以查查Can I Use。
相關(guān)文章
JavaScript數(shù)組去重算法實例小結(jié)
這篇文章主要介紹了JavaScript數(shù)組去重算法,結(jié)合實例形式總結(jié)分析了JavaScript數(shù)組去重相關(guān)的讀寫、遍歷、比較、排序等操作及算法改進相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2018-05-05
Google Map Api和GOOGLE Search Api整合實現(xiàn)代碼
將GOOGLE MAP API 和 GOOGLE Search API 進行整合,我用面向?qū)ο蟮姆绞綄懥艘粋€類,通過傳一個經(jīng)緯度進去,自動通過GOOGLE LOCAL SEARCH獲取附近的相關(guān)信息。比如餐廳、景點等,反過來標到地圖上,并可在任意容器內(nèi)顯示。2009-07-07
web網(wǎng)絡(luò)安全之跨站腳本攻擊(XSS)詳解
這篇文章主要介紹了web網(wǎng)絡(luò)安全之跨站腳本攻擊(XSS)的相關(guān)資料,跨站腳本攻擊XSS是一種常見的Web安全漏洞,攻擊者通過注入惡意腳本誘使用戶執(zhí)行,可能導致竊取敏感信息或執(zhí)行惡意操作,需要的朋友可以參考下2025-03-03

