1分鐘快速了解js實現(xiàn)下載文件功能的4種方式
1、a標簽下載 —可以直接下載txt、png、pdf、exe、xlsx等類型文件
downFile = (url) => { const a = document.createElement('a'); a.style.display = 'none'; a.download = 'xx'; a.href = url; document.body.appendChild(a); a.click(); document.body.removeChild(a); /* * download: HTML5新增的屬性 * url: 屬性的地址必須是非跨域的地址 */ };
2、new Blob 文件流下載
//fileName : 設置下載的文件名稱 //filestream: 返回的文件流 const blob = new Blob([filestream], {type: 'application/vnd.ms-excel'}); const a = document.createElement('a'); const href = window.URL.createObjectURL(blob); // 創(chuàng)建下載連接 a.href = href; a.download = decodeURI(fileName ); document.body.appendChild(a); a.click(); document.body.removeChild(a); // 下載完移除元素 window.URL.revokeObjectURL(href); // 釋放掉blob對象
3、window.open下載
window.open(url, '_self');
缺點:
會出現(xiàn)URL長度限制問題
需要注意url編碼問題
無法獲取下載進度
無法在header中攜帶token做鑒權(quán)操作
無法判斷接口是否成功
無法直接下載瀏覽器可直接預覽的文件類型(txt、png、pdf會直接預覽)
4、location.href 下載
window.location.href = url
缺點:
會出現(xiàn)URL長度限制問題
需要注意url編碼問題
無法獲取下載進度
無法在header中攜帶token做鑒權(quán)操作
無法直接下載瀏覽器可直接預覽的文件類型(txt、png、pdf會直接預覽)
無法判斷接口是否返回成功
總結(jié)
到此這篇關于js實現(xiàn)下載文件功能的4種方式的文章就介紹到這了,更多相關js下載文件功能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JS對象轉(zhuǎn)換為Jquery對象實現(xiàn)代碼
很多新手朋友們都不知道js對象如何轉(zhuǎn)換為jquery對象,其實很簡單,下面有個不錯的示例,感興趣的朋友可以參考下2013-12-12JavaScript基于ChatGPT?API實現(xiàn)劃詞翻譯瀏覽器腳本
最近?GitHub?上有個基于?ChatGPT?API?的瀏覽器腳本,openai-translator,?短時間內(nèi)?star?沖到了?9.7k,拋開?tauri?是使用?rust?部分,那瀏覽器部分實現(xiàn)還是比較簡單的,今天我們就來手動實現(xiàn)一下2023-03-03WebGame《逆轉(zhuǎn)裁判》完整版 代碼下載(1月24日更新)
WebGame《逆轉(zhuǎn)裁判》完整版 代碼下載(1月24日更新)...2007-01-01