前端使用a标签下载非同源文件(备选方案)
原理:
下载文件Blob,再把Blob转为本地链接,以实现跨域变同域,最后使用a标签实现下载;
优缺点:
● 优点:能达到下载跨域文件的目的;
● 缺点:不适用于大文件,大文件体验较差;
示例:
使用fetch把文件下载下来,然后URL.createObjectURL转为本地链接,最后使用a标签下载;
/** * 跨域文件下载 * @param url 附件地址 * @param download 附件可以预览或者下载 */ // 获取文件名 // 适用URL格式类似为:http://abc.com/xxx-file.jpg const getFileName = (url) => { const name = url.split('/').pop() return name.pop() } // 下载 export const fileDownload = (url) => { const filename = getFileName(url) fetch(url) .then(response => { return response.blob() }) .then(blob => { const blobUrl = window.URL.createObjectURL(blob) // 创建a标签下载 const tempLink = document.createElement('a') tempLink.style.display = 'none' tempLink.href = blobUrl tempLink.setAttribute('download', filename) document.body.appendChild(tempLink) tempLink.click() setTimeout(() => { URL.revokeObjectURL(blobUrl) document.body.removeChild(tempLink) }) }) }
原文链接:

作者:LiangSenCheng小森森 开源分享汇 公众号
出处:https://www.cnblogs.com/LiangSenCheng/p/17934719.html
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。如有问题或建议请联系作者,非常感谢。
标签:
JavaScript
, 经验
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!