移動端a標簽下載文件重命名(download)不生效解決辦法
項目場景:
移動端使用
a標簽下載文件
問題描述
下載的文件使用
download重命名不生效
APP 中接收數(shù)據(jù)代碼:
const link = document.createElement('a') // 創(chuàng)建a標簽
link.style.display = 'none' // 使其隱藏
link. // 賦予文件下載地址
link.setAttribute('download', `${dayjs(new Date()).format('YYYY-MM-DD HH:mm:ss')}`) // 設置下載屬性 以及文件名
document.body.appendChild(link) // a標簽插至頁面中
link.click() // 強制觸發(fā)a標簽事件
document.body.removeChild(link)

原因分析:
跨域問題:如果下載文件所在的服務器與當前頁面不在同一域名下,download屬性可能無法正常工作。這是因為跨域訪問限制了文件下載。
解決方案:
使用
fetch或者axios獲取數(shù)據(jù)流,轉(zhuǎn)成blob之后就是同源的文件了,此時可以使用a標簽正常下載了,注意需要添加請求頭'Content-Type': 'application/json;charset=UTF-8'
fetch('http://192.168.103.1:8080/factory/v1/group1/M00/00/30/wKhnWWa6xf2AEеKVAAAAFQHKOQM949.txt', {
method: 'get',
heanders: {
'Content-Type': 'application/json;charset=UTF-8'
}
})
.then(res => res.blob())
.then(blob => {
const link = document.createElement('a')
link.style.display = 'none'
link.download = `${dayjs(new Date()).format('YYYY-MM-DD HH:mm:ss')}`// 設置下載屬性 以及文件名
link.href = URL.createObjectURL(blob)
document.body.appendChild(link)
link.click()
// 釋放的 URL 對象以及移除 a 標簽
URL.revokeObjectURL(link.href)
document.body.removeChild(link)
})

總結(jié)
到此這篇關于移動端a標簽下載文件重命名(download)不生效解決辦法的文章就介紹到這了,更多相關a標簽下載文件重命名不生效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
ionic中的$ionicPlatform.ready事件中的通用設置
$ionicPlatform.ready事件是用于檢測當前的平臺是否就緒的事件,相當于基于document的deviceready事件, 在app中一些通用關于設備的設置必須在這個事件中處理2017-06-06

