在很多后台管理系统里可能会有导出表格,下载表格,下载压缩包等这样的需求。下面说几种简单的下载的方法:
一、运用标签完成
<a href="文件链接" download='下载文件名'></a>
但是这种办法有缺陷,代码其中的download对应音频文件和视频文件是无效的。还有个情况,比如txt,png,jpg等这些浏览器支持直接打开的文件是不会执行下载任务的,而是会直接打开文件,这个时候就需要给a标签添加一个属性“download”;
如果再vue项目中需要下载文件需要放在public文件夹下 需要下载的路径是相对于index.html文件路径 否则会提示下载文件未找到
二、运用js实现下载
<script>
const a = document.createElement('a');
a.setAttribute('href', '文件链接'); //a.href='文件链接'
a.setAttribute('download', '文件名'); //a.download='文件名'
a.click();
</script>
三、js中ajax实现音频或者视频不跳转进行文件下载
先理一下代码思路:
先请求音频的链接,再把返回值转换成二进制,再根据他二进制对象生成新链接,再创建a标签,点击a标签。具体代码实现如下:
//这是vue里面的写的普通页面也差不多
<script>
this.$axios({
method: 'get',
url: row.src,
responseType: 'blob' //这个不能少,让response二进制形式,如果你按照网上教程不设置这个将返回值进行BLOB([])进行处理可能会出现解析错误
}).then(response => {
const href = URL.createObjectURL(response.data); //根据二进制对象创造新的链接
const a = document.createElement('a');
a.setAttribute('href', href);
a.setAttribute('download', row.title);
a.click();
URL.revokeObjectURL(href);
}
</script>
四、fetch实现
fetch实现其实和Ajax的原理是一样的
function request() {
fetch('<接口地址>', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: '<请求参数:json字符串>',
})
.then(res => res.blob())
.then(data => {
let blobUrl = window.URL.createObjectURL(data);
download(blobUrl);
});
}
function download(blobUrl) {
const a = document.createElement('a');
a.download = '<文件名>';
a.href = blobUrl;
a.click();
}
request();
这些就是纯前端实现文件下载的方法,仅供参考,如有错误,大家帮忙纠正。