a标签下载出现预览场景

在开发者文档管理中,对于页面上的附件下载。一般快速实现方式,是使用a标签的download属性,直接下载文件。但是在测试中发现在一些特殊情况下,会变成在线预览。而对于开发需求中,json文件也要以附件形式下载,方便cp进行操作。本文针对这种情况说明及列举对应的解决方法。

1、使用a标签测试下载附件的现象

  • 在同源情况下,文件都可以正常下载
  • 不同源情况,部分文件(.json、.txt、.png等)会变成在线预览形式

2、a标签下载相关属性

download:设置该属性,可以让浏览器把地址视为在线下载资源

  • 如果没有指定值,浏览器会从多个来源决定文件名和扩展名:

  • filename:决定文件名的值。/ 和 `` 被转化为下划线(_)。文件系统可能会阻止文件名中其他的字符,因此浏览器会在必要时适当调整文件名。

href:设置下载地址,可以支持data:url,blob:url

注意:上述异常现象的原因是 download 只在同源 URLblob:data: 协议起作用

3、解决方法:

  • 不同源情况下,使用data:url或者blob:url处理,变成同源文件处理
javascript 复制代码
//blob:url,处理各种文件
    fetch("http://127.0.0.1:3000/test.png")
        .then(res => res.blob()).then(res => {
        document.querySelector("#file").href = URL.createObjectURL(res);
    })
//data:url处理指定文件
    fetch("http://127.0.0.1:3000/test.json")
        .then(res => res.text())
            .then(res => {
            document.querySelector("#file").href = `data:application/json,${res}`;
    })
  • 使用Content-Disposition 在服务端 设置HTTP 响应头设置,设置为附件形式attachment
css 复制代码
Content-Disposition: attachment;filename="fname";
  • 使用代理方案,变成同源文件处理

参考

相关推荐
XiYang-DING7 分钟前
JavaScript
开发语言·javascript·ecmascript
空中海1 小时前
02 React Native状态、导航、数据流与设备能力
javascript·react native·react.js
空中海2 小时前
02 状态、Hooks、副作用与数据流
开发语言·javascript·ecmascript
空中海2 小时前
04 React Native工程化、质量、发布与生态选型
javascript·react native·react.js
杨超凡3 小时前
豆包收费了?我特么自己用“意念”搓了一个!
javascript
threelab3 小时前
Three.js 咖啡杯烟雾效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
Heo4 小时前
14_React 中的更新队列 updateQueue
前端·javascript·面试
前端 贾公子4 小时前
解决浏览器端 globalThis is not defined 报错
前端·javascript·vue.js
码农小河664 小时前
AI 一键生成 HTML/CSS/JS 静态网站【压缩包返回可直接提交】
css·人工智能·html