js實(shí)現(xiàn)文件下載

https://scarletsky.github.io/2016/07/03/download-file-using-javascript/
http://blog.csdn.net/androidmi/article/details/7519243

通過ajax請(qǐng)求服務(wù)器實(shí)現(xiàn)文件下載是我們?cè)诰W(wǎng)頁(yè)開發(fā)過程中經(jīng)常遇到的需求,我的解決方案有兩種:

有可用的url

這種情況下可以可以通過創(chuàng)建<a>并模擬點(diǎn)擊來實(shí)現(xiàn)喚醒下載窗口,代碼如下:

let a = document.createElement('a');
a.href = url;
a.download = 'filename.txt';
a.click();

只要為<a> 標(biāo)簽添加 download屬性瞭稼,我們點(diǎn)擊這個(gè)鏈接的時(shí)候就會(huì)自動(dòng)下載文件了潮剪。download 的屬性值是可選的,它用來指定下載文件的文件名袁稽。

無可用的url

此時(shí)就需要通過ajax向后臺(tái)腳本發(fā)起請(qǐng)求勿璃,后臺(tái)的node.js響應(yīng)代碼如下

res.set({
            'Content-Type': 'application/octet-stream',
            'Content-Disposition': 'attachment; filename=filename.txt',
            'Content-Length': 1000
});
//file是服務(wù)器上的文件的具體路徑
fs.createReadStream(file).pipe(res);

響應(yīng)頭設(shè)為application/octet-stream,表示傳遞的數(shù)據(jù)是二進(jìn)制流推汽,這是由node.js中流操作所產(chǎn)生的數(shù)據(jù)類型
Content-Disposition設(shè)為attachment會(huì)彈出對(duì)話框讓用戶下載补疑,filename是保存的文件名

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市歹撒,隨后出現(xiàn)的幾起案子莲组,更是在濱河造成了極大的恐慌,老刑警劉巖栈妆,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胁编,死亡現(xiàn)場(chǎng)離奇詭異厢钧,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)嬉橙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門早直,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人市框,你說我怎么就攤上這事霞扬。” “怎么了枫振?”我有些...
    開封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵喻圃,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我粪滤,道長(zhǎng)斧拍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任杖小,我火速辦了婚禮肆汹,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘予权。我一直安慰自己昂勉,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開白布扫腺。 她就那樣靜靜地躺著岗照,像睡著了一般。 火紅的嫁衣襯著肌膚如雪笆环。 梳的紋絲不亂的頭發(fā)上攒至,一...
    開封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音咧织,去河邊找鬼嗓袱。 笑死,一個(gè)胖子當(dāng)著我的面吹牛习绢,可吹牛的內(nèi)容都是我干的渠抹。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼闪萄,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼梧却!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起败去,我...
    開封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤放航,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后圆裕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體广鳍,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡荆几,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了赊时。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吨铸。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖祖秒,靈堂內(nèi)的尸體忽然破棺而出诞吱,到底是詐尸還是另有隱情,我是刑警寧澤竭缝,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布房维,位于F島的核電站,受9級(jí)特大地震影響抬纸,放射性物質(zhì)發(fā)生泄漏咙俩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一湿故、第九天 我趴在偏房一處隱蔽的房頂上張望暴浦。 院中可真熱鬧,春花似錦晓锻、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至屑墨,卻和暖如春躁锁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背卵史。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工战转, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人以躯。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓槐秧,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親忧设。 傳聞我的和親對(duì)象是個(gè)殘疾皇子刁标,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 項(xiàng)目中用到了二維碼點(diǎn)擊下載,下面是實(shí)現(xiàn)方式html js php 用到了endroid/qrcode,請(qǐng)使用com...
    April2閱讀 1,706評(píng)論 2 1
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)址晕,斷路器膀懈,智...
    卡卡羅2017閱讀 134,629評(píng)論 18 139
  • 本文包括:1、文件上傳概述2谨垃、利用 Commons-fileupload 組件實(shí)現(xiàn)文件上傳3启搂、核心API——Dis...
    廖少少閱讀 12,528評(píng)論 5 91
  • Node.js是目前非撑鹂兀火熱的技術(shù),但是它的誕生經(jīng)歷卻很奇特胳赌。 眾所周知牢撼,在Netscape設(shè)計(jì)出JavaScri...
    w_zhuan閱讀 3,609評(píng)論 2 41
  • 這一講主要包含以下幾個(gè)部分: 1.創(chuàng)建商品列表頁(yè) 2.根據(jù)分類獲取商品列表 2.展示商品列表 1.創(chuàng)建商品列表頁(yè) ...
    IonicBlog閱讀 10,695評(píng)論 15 11