a标签下载pdf、excel、图片等文件

文章讲述了如何使用HTML的a标签配合download属性实现PDF文件的下载,包括download属性可能因跨域限制而失效的情况,以及通过添加response-content-type参数为application/octet-stream来强制浏览器下载。此外,还介绍了通过动态创建a标签的方式来规避跨域限制,实现文件下载的方法。
摘要由CSDN通过智能技术生成
<a href="...pdf?response-content-type=application/octet-stream" download target="_blank"></a>

1、a标签中添加download属性,但是这个方法有时候会失效,这是因为download不支持跨域请求,网站和pdf文件必须在同一域名下才可行,不然就是先打开一个新标签预览
2、在pdf文件下载链接后加response-content-type=application/octet-stream,在浏览器中打开pdf文件链接时,浏览器会默认进行下载
3、动态创建a标签进行下载

let url = data.url+'?response-content-type=application/octet-stream';// data.url路径地址
downloadFile(url)
function downloadFile(url) {
    //下载文件
    let a = document.createElement("a");
    a.setAttribute("href", url);
    a.setAttribute("download",'download');
    a.setAttribute("target", "_blank");
    let clickEvent = document.createEvent("MouseEvents");
    clickEvent.initEvent("click", true, true);
    a.dispatchEvent(clickEvent);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值