JavaScript实现文件下载并重命名代码实例
这篇文章主要介绍了JavaScript实现文件下载并重命名代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
第一种是HTML官网中的方法
HTML5中a标签提供了一个filename属性,可以下载成指定的download属性名称
这种同源访问是没有问题的,但一跨域就不行了,试了其它方法,不是报跨域错误,就是在当前页面打开文件,体验相当不好。
第二种方案比较通用
/**
*获取blob
*url目标文件地址
*/
functiongetBlob(url){
returnnewPromise(resolve=>{
constxhr=newXMLHttpRequest();
xhr.open('GET',url,true);
xhr.responseType='blob';
xhr.onload=()=>{
if(xhr.status===200){
resolve(xhr.response);
}
};
xhr.send();
});
}
/**
*保存blob
*filename想要保存的文件名称
*/
functionsaveAs(blob,filename){
if(window.navigator.msSaveOrOpenBlob){
navigator.msSaveBlob(blob,filename);
}else{
constlink=document.createElement('a');
constbody=document.querySelector('body');
link.href=window.URL.createObjectURL(blob);
link.download=filename;
//fixFirefox
link.style.display='none';
body.appendChild(link);
link.click();
body.removeChild(link);
window.URL.revokeObjectURL(link.href);
}
}
/**
*下载
*@param{String}url目标文件地址
*@param{String}filename想要保存的文件名称
*/
functiondownload(url,filename){
getBlob(url).then(blob=>{
saveAs(blob,filename);
});
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。