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";
  • 使用代理方案,变成同源文件处理

参考

相关推荐
一 乐16 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
xkxnq19 小时前
第二阶段:Vue 组件化开发(第 16天)
前端·javascript·vue.js
Van_Moonlight19 小时前
RN for OpenHarmony 实战 TodoList 项目:空状态占位图
javascript·开源·harmonyos
xkxnq19 小时前
第一阶段:Vue 基础入门(第 15天)
前端·javascript·vue.js
BBBBBAAAAAi20 小时前
Claude Code安装记录
开发语言·前端·javascript
源码获取_wx:Fegn089521 小时前
基于 vue智慧养老院系统
开发语言·前端·javascript·vue.js·spring boot·后端·课程设计
Jing_Rainbow21 小时前
【 前端三剑客-37 /Lesson61(2025-12-09)】JavaScript 内存机制与执行原理详解🧠
前端·javascript·程序员
UIUV1 天前
模块化CSS学习笔记:从作用域问题到实战解决方案
前端·javascript·react.js
松涛和鸣1 天前
49、智能电源箱项目技术栈解析
服务器·c语言·开发语言·http·html·php
Kakarotto1 天前
使用ThreeJS绘制东方明珠塔模型
前端·javascript·vue.js