Web前端下載圖片/文件

Web前端下載圖片/文件

條條道路通羅馬家夺,這里只記錄a標(biāo)簽下載圖片/文件的方法。

  /** 下載文件 **/
  downFile(content:any, filename:string) {
      let ele = document.createElement('a');// 創(chuàng)建下載鏈接
      ele.download = filename;//設(shè)置下載的名稱
      ele.style.display = 'none';// 隱藏的可下載鏈接
      // 字符內(nèi)容轉(zhuǎn)變成blob地址
      var blob = new Blob([content]);
      ele.href = URL.createObjectURL(blob);
      document.body.appendChild(ele);
      ele.click();
      // 然后移除
      URL.revokeObjectURL(ele.href)
      document.body.removeChild(ele);
  }
  /**
   * @param url 圖片地址 也支持base64格式的url
   * @param filename  文件名
   * **/ 
  downImg(url:string,filename:string){
    let ele = document.createElement('a');// 創(chuàng)建下載鏈接
      ele.download = filename;//設(shè)置下載的名稱
      ele.style.display = 'none';// 隱藏的可下載鏈接
      ele.href = url;
      document.body.appendChild(ele);
      ele.click();
      // 然后移除
      URL.revokeObjectURL(ele.href)
      document.body.removeChild(ele);
  }
文件類型MIME

Blob 對象表示一個不可變伐弹、原始數(shù)據(jù)的類文件對象拉馋。
new Blob( array[, options] ) ,第二個參數(shù)options可選的參數(shù)掸茅。

  • array 是一個由ArrayBuffer, ArrayBufferView, Blob, DOMString 等對象構(gòu)成的 Array 椅邓,或者其他類似對象的混合體柠逞,它將會被放進(jìn) Blob昧狮。DOMStrings會被編碼為UTF-8。
  • options 是一個可選的BlobPropertyBag字典板壮,它可能會指定如下兩個屬性:
    • type逗鸣,默認(rèn)值為 "",它代表了將會被放入到blob中的數(shù)組內(nèi)容的MIME類型绰精。
    • endings撒璧,默認(rèn)值為"transparent",用于指定包含行結(jié)束符\n的字符串如何被寫入笨使。 它是以下兩個值中的一個: "native"卿樱,代表行結(jié)束符會被更改為適合宿主操作系統(tǒng)文件系統(tǒng)的換行符,或者 "transparent"硫椰,代表會保持blob中保存的結(jié)束符不變
不同的文件需要設(shè)置相對應(yīng)type類型繁调,否則可能導(dǎo)致下載的文件是亂碼萨蚕。
擴(kuò)展名 文檔類型 MIME 類型
.aac AAC audio audio/aac
.abw AbiWord document application/x-abiword
.arc Archive document (multiple files embedded) application/x-freearc
.avi AVI: Audio Video Interleave video/x-msvideo
.azw Amazon Kindle eBook format application/vnd.amazon.ebook
.bin Any kind of binary data application/octet-stream
.bmp Windows OS/2 Bitmap Graphics image/bmp
.bz BZip archive application/x-bzip
.bz2 BZip2 archive application/x-bzip2
.csh C-Shell script application/x-csh
.css Cascading Style Sheets (CSS) text/css
.csv Comma-separated values (CSV) text/csv
.doc Microsoft Word application/msword
.docx Microsoft Word (OpenXML) application/vnd.openxmlformats-officedocument.wordprocessingml.document
.eot MS Embedded OpenType fonts application/vnd.ms-fontobject
.epub Electronic publication (EPUB) application/epub+zip
.gif Graphics Interchange Format (GIF) image/gif
`.htm
.html` HyperText Markup Language (HTML) text/html
.ico Icon format image/vnd.microsoft.icon
.ics iCalendar format text/calendar
.jar Java Archive (JAR) application/java-archive
.jpeg
.jpg JPEG images image/jpeg
.js JavaScript text/javascript
.json JSON format application/json
.jsonld JSON-LD format application/ld+json
.mid
.midi Musical Instrument Digital Interface (MIDI) audio/midi audio/x-midi
.mjs JavaScript module text/javascript
.mp3 MP3 audio audio/mpeg
.mpeg MPEG Video video/mpeg
.mpkg Apple Installer Package application/vnd.apple.installer+xml
.odp OpenDocument presentation document application/vnd.oasis.opendocument.presentation
.ods OpenDocument spreadsheet document application/vnd.oasis.opendocument.spreadsheet
.odt OpenDocument text document application/vnd.oasis.opendocument.text
.oga OGG audio audio/ogg
.ogv OGG video video/ogg
.ogx OGG application/ogg
.otf OpenType font font/otf
.png Portable Network Graphics image/png
.pdf Adobe Portable Document Format (PDF) application/pdf
.ppt Microsoft PowerPoint application/vnd.ms-powerpoint
.pptx Microsoft PowerPoint (OpenXML) application/vnd.openxmlformats-officedocument.presentationml.presentation
.rar RAR archive application/x-rar-compressed
.rtf Rich Text Format (RTF) application/rtf
.sh Bourne shell script application/x-sh
.svg Scalable Vector Graphics (SVG) image/svg+xml
.swf Small web format (SWF) or Adobe Flash document application/x-shockwave-flash
.tar Tape Archive (TAR) application/x-tar
`.tif
.tiff` Tagged Image File Format (TIFF) image/tiff
.ttf TrueType Font font/ttf
.txt Text, (generally ASCII or ISO 8859-n) text/plain
.vsd Microsoft Visio application/vnd.visio
.wav Waveform Audio Format audio/wav
.weba WEBM audio audio/webm
.webm WEBM video video/webm
.webp WEBP image image/webp
.woff Web Open Font Format (WOFF) font/woff
.woff2 Web Open Font Format (WOFF) font/woff2
.xhtml XHTML application/xhtml+xml
.xls Microsoft Excel application/vnd.ms-excel
.xlsx Microsoft Excel (OpenXML) application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
.xml XML application/xml 代碼對普通用戶來說不可讀 (RFC 3023, section 3)
text/xml 代碼對普通用戶來說可讀 (RFC 3023, section 3)
.xul XUL application/vnd.mozilla.xul+xml
.zip ZIP archive application/zip
.3gp 3GPP audio/video container video/3gpp
audio/3gpp(若不含視頻)
.3g2 3GPP2 audio/video container video/3gpp2
audio/3gpp2(若不含視頻)
.7z 7-zip archive application/x-7z-compressed
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蹄胰,隨后出現(xiàn)的幾起案子岳遥,更是在濱河造成了極大的恐慌,老刑警劉巖裕寨,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浩蓉,死亡現(xiàn)場離奇詭異,居然都是意外死亡宾袜,警方通過查閱死者的電腦和手機捻艳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來庆猫,“玉大人讯泣,你說我怎么就攤上這事≡暮罚” “怎么了好渠?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長节视。 經(jīng)常有香客問我拳锚,道長,這世上最難降的妖魔是什么寻行? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任霍掺,我火速辦了婚禮,結(jié)果婚禮上拌蜘,老公的妹妹穿的比我還像新娘杆烁。我一直安慰自己,他們只是感情好简卧,可當(dāng)我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布兔魂。 她就那樣靜靜地躺著,像睡著了一般举娩。 火紅的嫁衣襯著肌膚如雪析校。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天铜涉,我揣著相機與錄音智玻,去河邊找鬼。 笑死芙代,一個胖子當(dāng)著我的面吹牛吊奢,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播纹烹,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼页滚,長吁一口氣:“原來是場噩夢啊……” “哼谬泌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起逻谦,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤掌实,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后邦马,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贱鼻,經(jīng)...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年滋将,在試婚紗的時候發(fā)現(xiàn)自己被綠了邻悬。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡随闽,死狀恐怖父丰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情掘宪,我是刑警寧澤蛾扇,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站魏滚,受9級特大地震影響镀首,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鼠次,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一更哄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧腥寇,春花似錦成翩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至扩劝,卻和暖如春庸论,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背棒呛。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留域携,地道東北人簇秒。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像秀鞭,于是被迫代替她去往敵國和親趋观。 傳聞我的和親對象是個殘疾皇子扛禽,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,435評論 2 359

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