a标签跳转下载 并且阻止新网页跳转
利用a标签下载
一、a标签下载文件
<a href="完整下载地址"></a>
但是这样会有一个问题,就是下载是可以下载了,但是同样触发了a标签的页面跳转功能。
<a :href="`${完整的下载地址}`" target="downloadFile">{{文件名称}}</a>
<iframe style="display: none;" name="downloadFile"></iframe>
二. 动态生成a标签下载
// 用fetch发送请求 对请求回来的二进制文件流进行处理
fetch('/upload/user.png').then((res) => {
res.blob().then((blob) => {
const blobUrl = window.URL.createObjectURL(blob);
// 这里的文件名根据实际情况从响应头或者url里获取
const filename = 'user.txt';
const a = document.createElement('a');
a.href = blobUrl;
a.download = filename;
a.click();
window.URL.revokeObjectURL(blobUrl);
});
});
注:如果遇到下载 txt、jpg 等文件时出现直接打开文件而不是下载文件的情况时,可以在下载地址即 url 后拼接 ‘?response-content-type=application/octet-stream’ 即可
三. 阻止a标签跳转的5中方法
- 在标签里面添加点击事件,直接 return false
<a href="https://www.jd.com" onclick="alert('哈哈');return false;">跳转1</a>
- 在函数内直接return false (用的最多)
<a href="https://www.jd.com" id='link2'>跳转2</a>
<script>
let link2 = document.getElementById('link2');
link2.onclick = function(){
alert('呵呵');
return false;
}
</script>
- 这种方法类似2,在函数内return false 然后a再调用,调用没有括号
<a href="https://www.jd.com" id='link3'>跳转3</a>
<script>
let link3 = document.getElementById('link3');
link2.onclick =text; //注意这里不加括号
function text(){
alert('呵呵');
return false;
}
</script>
- 点击a,调用test方法,得到的false返回值再返回给a标签
<a href="https://www.jd.com" onclick="return test()" id="link4">跳转4</a>
<script>
function text(){
alert('呵呵');
return false;
}
</script>
- 京东网站的写法,很常用
<a href="javascript:void(0);" onclick="test()" id="link5">跳转5</a>
洗尽铅华始见金,褪去浮华归本真
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
2022-02-14 vee-validate 表单验证插件 的基本使用【个人目标:学会使用即可】