亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

復(fù)制代碼 代碼如下:

<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,如:

復(fù)制代碼 代碼如下:

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

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

那么,現(xiàn)在要將js生成的內(nèi)容進(jìn)行下載就有法可依了。封裝成一個(gè)方法如下:

復(fù)制代碼 代碼如下:

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)在來看看最終代碼:

復(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 不加后兩個(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)顯隱效果【測試可用】

    這篇文章主要介紹了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-06
  • 談?wù)凧avaScript令人迷惑的==與+

    談?wù)凧avaScript令人迷惑的==與+

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

    使用 JavaScript 制作頁面效果

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

    uniapp上傳圖片和上傳視頻的實(shí)現(xiàn)方法

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

    uniapp實(shí)現(xiàn)全局設(shè)置字體大小(小中大的字體切換)

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

    JS中cookie的使用及缺點(diǎn)講解

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

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

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

    echarts多條折線圖動(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-05
  • JS實(shí)現(xiàn)時(shí)間軸自動(dòng)播放

    JS實(shí)現(xiàn)時(shí)間軸自動(dòng)播放

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

    html的DOM中document對象images集合用法實(shí)例

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

最新評論