欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用JS在瀏覽器中創(chuàng)建下載文件

 更新時間:2014年03月05日 18:00:05   投稿:junjie  
前端很多項目中,都有文件下載的需求,特別是JS生成文件內容,然后讓瀏覽器執(zhí)行下載操作(例如在線圖片編輯、在線代碼編輯、iPresst等

但受限于瀏覽器,很多情況下我們都只能給出個鏈接,讓用戶點擊打開-》另存為。如下面這個鏈接:

復制代碼 代碼如下:

<a href=”file.js”>file.js</a>

用戶點擊這個鏈接的時候,瀏覽器會打開并顯示鏈接指向的文件內容,顯然,這并沒有實現我們的需求。HTML5中給a標簽增加了一個download屬性,只要有這個屬性,點擊這個鏈接時瀏覽器就不在打開鏈接指向的文件,而是改為下載(目前只有chrome、firefox和opera支持)。

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

但是這樣還不夠,以上的方法只適合用在文件是在服務器上的情況。如果在瀏覽器端js生成的內容,想讓瀏覽器進行下載要如何辦到呢?

其實還是有辦法辦到的,相信很多人都多少聽過了DataURI這個詞,比較常見的就是圖片的src,如:

復制代碼 代碼如下:

<img src=”data:image/gif;base64,R0lGOXXXXX">

DataURI的解釋可以移步這里,本人就不在解釋了。

那么,現在要將js生成的內容進行下載就有法可依了。封裝成一個方法如下:

復制代碼 代碼如下:

function downloadFile(aLink, fileName, content){

    aLink.download = fileName;
    aLink.href = "data:text/plain," + content;
}

調用downloadFile之后,用戶點擊鏈接,就能觸發(fā)瀏覽器下載。

但是,還不夠,上面的辦法有兩個硬傷,會導致流失很多懶人美眉:

下載的文件類型限制死了,美眉要下載處理后的果照怎么辦?
下載還要再點擊一下,太麻煩啦。
要解決文件類型的問題,可以用瀏覽器的新API(URL.createObjectURL)來解決問題,URL.createObjectURL通常都是用來創(chuàng)建圖片的DataURI用來顯示圖片,這里用來下載文件,讓瀏覽器來幫我們設定好文件類型。

URL.createObjectURL的參數是File對象或者Blob對象,File對象也就是通過input[type=file]選擇的文件,Blob對象是二進制大對象,詳細說明可參考這里。

現在,我們只要用content創(chuàng)建一個ObjectURL并賦值給aLink即可解決文件類型的限制問題。
文件的自動下載也挺好辦,自己構建一個UI點擊事件,再自動觸發(fā)下,就能實現自動下載啦。

現在來看看最終代碼:

復制代碼 代碼如下:

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 不加后兩個參數在FF下會報錯, 感謝 Barret Lee 的反饋
    aLink.download = fileName;
    aLink.href = URL.createObjectURL(blob);
    aLink.dispatchEvent(evt);
}

現在,只要一調用downloadFile,文件就自動下載了,是不是很爽咧,^_^。

注:目前(2014-01)Blob和URL.createObjectURL在標準瀏覽器里面都不再需要加私有前綴,可以放心使用啦啦啦~~如果你不放心,可以查查Can I Use。

相關文章

  • JS基于構造函數實現的菜單滑動顯隱效果【測試可用】

    JS基于構造函數實現的菜單滑動顯隱效果【測試可用】

    這篇文章主要介紹了JS基于構造函數實現的菜單滑動顯隱效果,可實現基本的菜單折疊與展開功能,涉及javascript響應鼠標事件動態(tài)操作頁面元素的相關技巧,需要的朋友可以參考下
    2016-06-06
  • 談談JavaScript令人迷惑的==與+

    談談JavaScript令人迷惑的==與+

    這篇文章主要介紹了JavaScript中==與+的使用方法,幫助大家更好的理解和學習JavaScript,感興趣的朋友可以了解下
    2020-08-08
  • 使用 JavaScript 制作頁面效果

    使用 JavaScript 制作頁面效果

    這篇文章主要介紹了使用 JavaScript 制作頁面效果,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • uniapp上傳圖片和上傳視頻的實現方法

    uniapp上傳圖片和上傳視頻的實現方法

    這篇文章主要給大家介紹了關于uniapp上傳圖片和上傳視頻的實現方法,文中還介紹了上傳文件的方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • uniapp實現全局設置字體大小(小中大的字體切換)

    uniapp實現全局設置字體大小(小中大的字體切換)

    隨著UniApp的流行,越來越多的開發(fā)者選擇使用它來構建跨平臺應用程序,下面這篇文章主要給大家介紹了關于uniapp實現全局設置字體大小(小中大的字體切換)的相關資料,需要的朋友可以參考下
    2023-06-06
  • JS中cookie的使用及缺點講解

    JS中cookie的使用及缺點講解

    Cookie就是這樣的一種機制。它可以彌補HTTP協(xié)議無狀態(tài)的不足。在Session出現之前,基本上所有的網站都采用Cookie來跟蹤會話。下面通過本文給大家介紹JS中cookie的使用及缺點,需要的朋友參考下吧
    2017-05-05
  • js 轉json格式的字符串為對象或數組(前后臺)的方法

    js 轉json格式的字符串為對象或數組(前后臺)的方法

    下面小編就為大家?guī)硪黄猨s 轉json格式的字符串為對象或數組(前后臺)的方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • echarts多條折線圖動態(tài)分層的實現方法

    echarts多條折線圖動態(tài)分層的實現方法

    這篇文章主要介紹了echarts多條折線圖動態(tài)分層的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • JS實現時間軸自動播放

    JS實現時間軸自動播放

    這篇文章主要為大家詳細介紹了JS實現時間軸自動播放,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • html的DOM中document對象images集合用法實例

    html的DOM中document對象images集合用法實例

    這篇文章主要介紹了html的DOM中document對象images集合用法,實例分析了images集合的語法與使用技巧,需要的朋友可以參考下
    2015-01-01

最新評論