需求:拥有URL,需下载并自定义文件名字
//传入url路径以及文件名即可
function myDownLoad(url,fileName){
getBolb(url).then((blob)=>{
saveAs(blob,fileName)
})
}
function getBolb(url){
return new Promise(resolve=>{
const xhr = new XMLHttpRequest()
xhr.open('GET',url,true)
xhr.responseType = 'blob'
xhr.onload =()=>{
if(xhr.status === 200){
resolve(xhr.response)
}
}
xhr.send()
})
}
function saveAs(blob, filename) {
if (window.navigator.msSaveOrOpenBlob) {
navigator.msSaveBlob(blob, filename)
} else {
const link = document.createElement('a')
const body = document.querySelector('body')
link.href = window.URL.createObjectURL(blob)
link.download = filename
// fix Firefox
link.style.display = 'none'
body.appendChild(link)
link.click()
body.removeChild(link)
window.URL.revokeObjectURL(link.href)
}
}
摘自文章:JS通过url下载文件并修改文件名_pany_k的博客-优快云博客_js 文件下载指定文件名