前端下載文件

PC或者移動(dòng)端下載文件(包括excel堕战、圖片等)到本地

一阅悍、方案

根據(jù)平臺(tái)有不同的方案:

  • PC
    主要使用 window.open 方法,直接調(diào)用接口履怯,接口返回文件直接下載

  • 移動(dòng)端
    主要通過 file\img 轉(zhuǎn) base64艇潭,通過 a[download] 來下載

二拼窥、代碼實(shí)現(xiàn)

2.1 PC

如果下載接口需要登錄態(tài),且通過 cookie 傳遞

window.open(接口, '_blank');

如果下載接口需要登錄態(tài)蹋凝,且通過自定義 headers 字段傳遞

// 下載文件流
// axios 需要傳 responseType: 'blob'鲁纠,和 url data 平級(jí)
export function downloadTemplate(data = {}, headers = {}) {
  return request({
    url: '/web/addFriend/downloadTemplate',
    method: 'get',
    responseType: 'blob',
    data,
    headers
  })
}

// 使用 blob atag 進(jìn)行下載
// 這里的 res 需要使用 axios 的整個(gè) response,可以通過 response.headers['content-type'].indexOf('application/octet-stream') !== -1 判斷
function downloadFile(res) {
  const url = window.URL.createObjectURL(new Blob([res.data]))
  // 生成一個(gè)a標(biāo)簽
  let link = document.createElement('a')
  link.style.display = 'none'
  link.href = url
  // 生成文件名仙粱,并且去掉多余的雙引號(hào)
  const fileNameStr = res.headers['content-disposition'].split(';').find(item => item.indexOf('filename') !== -1)
  const fileName = fileNameStr ? fileNameStr.substring(fileNameStr.indexOf('=') + 1).replace(/\"/g, '') : Date.now()
  link.download = decodeURIComponent(fileName)
  link.click()
  link = null
}
// 這里需要判斷一下返回結(jié)果,因?yàn)橛锌赡芊祷氐氖且粋€(gè)報(bào)錯(cuò)
// 參考這篇文章 http://www.reibang.com/p/26f23345a4be

2.2 移動(dòng)端

/**
 * URL 轉(zhuǎn) base64
 **/
convertImgToBase64 (url, callback) {
  return new Promise(resolve => {
    const img = new Image();
    // 圖片域名要開啟跨域
    // canvas 不能處理跨域圖片彻舰,執(zhí)行 canvas 操作前也要開啟跨域
    img.crossOrigin = 'Anonymous';
    img.onload = function() {
      let canvas = document.createElement('canvas');
      const ctx = canvas.getContext('2d');
      canvas.height = this.height;
      canvas.width = this.width;
      ctx.drawImage(this, 0, 0);
      const imgBase64 = canvas.toDataURL("image/png");
      canvas = null;
      resolve(imgBase64);
    };
    img.src = url;
  })
},
// 下載
handleSave() {
  this.convertImgToBase64(this.url)
    .then(imgBase64 => {
      const a = document.createElement("a");
      const event = new MouseEvent("click");
      a.download = name || "photo";
      a.href = imgBase64;
      a.dispatchEvent(event);
    });
}

三伐割、遇到的問題

暫無

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市刃唤,隨后出現(xiàn)的幾起案子隔心,更是在濱河造成了極大的恐慌,老刑警劉巖尚胞,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件硬霍,死亡現(xiàn)場離奇詭異,居然都是意外死亡笼裳,警方通過查閱死者的電腦和手機(jī)唯卖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門粱玲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人拜轨,你說我怎么就攤上這事抽减。” “怎么了橄碾?”我有些...
    開封第一講書人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵卵沉,是天一觀的道長。 經(jīng)常有香客問我法牲,道長史汗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任拒垃,我火速辦了婚禮停撞,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘恶复。我一直安慰自己怜森,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開白布谤牡。 她就那樣靜靜地躺著副硅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪翅萤。 梳的紋絲不亂的頭發(fā)上恐疲,一...
    開封第一講書人閱讀 51,292評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音套么,去河邊找鬼培己。 笑死,一個(gè)胖子當(dāng)著我的面吹牛胚泌,可吹牛的內(nèi)容都是我干的省咨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼玷室,長吁一口氣:“原來是場噩夢啊……” “哼零蓉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起穷缤,我...
    開封第一講書人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤敌蜂,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后津肛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體章喉,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秸脱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片落包。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖撞反,靈堂內(nèi)的尸體忽然破棺而出妥色,到底是詐尸還是另有隱情,我是刑警寧澤遏片,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布嘹害,位于F島的核電站,受9級(jí)特大地震影響吮便,放射性物質(zhì)發(fā)生泄漏笔呀。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一髓需、第九天 我趴在偏房一處隱蔽的房頂上張望许师。 院中可真熱鬧,春花似錦僚匆、人聲如沸微渠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽逞盆。三九已至,卻和暖如春松申,著一層夾襖步出監(jiān)牢的瞬間云芦,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來泰國打工贸桶, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留舅逸,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓皇筛,卻偏偏與公主長得像琉历,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子水醋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

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

  • 1旗笔、使用a標(biāo)簽 eg: 2、winddow.open eg: window.open(url) 3离例、form表單模...
    msyrrr閱讀 1,403評(píng)論 0 1
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,100評(píng)論 1 32
  • 點(diǎn)擊查看原文 Web SDK 開發(fā)手冊 SDK 概述 網(wǎng)易云信 SDK 為 Web 應(yīng)用提供一個(gè)完善的 IM 系統(tǒng)...
    layjoy閱讀 13,760評(píng)論 0 15
  • 昨天的活動(dòng)成功换团! 我喜歡這樣的感覺悉稠,來來往往的客人宫蛆,促膝飲茶,閑余之際安靜看他們聊天,教一點(diǎn)手語耀盗。 二姐很厲害想虎,開...
    砥礪_b109閱讀 49評(píng)論 0 0
  • 難忘的第一次出差 2018年8月,吳江小伙子屠思堯從江蘇...
    蘇州的薔薇花開閱讀 1,852評(píng)論 7 25