前端下载图片、pdf、excel、world文件;前端下载图片和pdf文件;前端a标签下载图片和pdf文件;下载文件名称不生效原因
https://blog.csdn.net/i_am_a_div/article/details/125050379
https://blog.csdn.net/moguzhale/article/details/107704621?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522165390015016782425114724%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=165390015016782425114724&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduend~default-2-107704621-null-null.142%5Ev11%5Epc_search_result_control_group,157%5Ev12%5Econtrol&utm_term=%E5%89%8D%E7%AB%AF%E5%9B%BE%E7%89%87%E4%B8%8B%E8%BD%BD&spm=1018.2226.3001.4187
https://blog.csdn.net/snsHL9db69ccu1aIKl9r/article/details/119362095?ops_request_misc=&request_id=&biz_id=102&utm_term=%E5%89%8D%E7%AB%AF%E5%9B%BE%E7%89%87%E4%B8%8B%E8%BD%BD&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-0-119362095.142%5Ev11%5Epc_search_result_control_group,157%5Ev12%5Econtrol&spm=1018.2226.3001.4187
参考文章1参考文章2
以下的下载是,拿到了后端给的下载图片的接口地址url
> 方法1:将文本或者JS字符串通过 Blob 转换成二进制下载
优点:可以下载,也可以保存名称。
//文件流参数和图片名称function downloadTxt(str, filename){    let a = document.createElement('a')    a.download = filename    a.style.display = 'none'    let blob = new Blob([str])    a.href = URL.createObjectURL(blob)    document.body.appendChild(a)    a.dispatchEvent(new MouseEvent('click'))    document.body.removeChild(a)}
123456789101112> 方法2:原生的下载方法
优点:可以下载,也可以保存名称。 推荐!!!!
    downLoadFileImg (fileUrl, fileName) {      // fileUrl -- 后端下载地址 可能是拼接了文件id, fileName -- 下载文件名称        // 可以下载 没名称      // location.href = fileUrl
      // 可以下载 但是名称设置无效      // let a = document.createElement('a')      // a.download = fileName      // a.href = fileUrl      // a.dispatchEvent(new MouseEvent('click'))
      // 名称设置有效但是下载文件打不开      // // let a = document.createElement('a')      // // a.download = fileName //图片名称      // // a.style.display = 'none'      // // let blob = new Blob([fileUrl]) //图片地址      // // a.href = URL.createObjectURL(blob)      // // document.body.appendChild(a)      // // a.dispatchEvent(new MouseEvent('click'))      // // document.body.removeChild(a)
      // 会打开新的页面下载 但是没名称      // const newWindow = window.open()      // newWindow.document.write(      //   '<iframe width="100%" height="100%" src="' + fileUrl +      //   '" frameborder="0" allowfullscreen></iframe>'      // )      // newWindow.document.title = fileName
      // 可下载,名称也有效 -- 推荐      const x = new window.XMLHttpRequest()      x.open('GET', fileUrl, true)      x.responseType = 'blob'      x.onload = () => {        const url = window.URL.createObjectURL(x.response)        const a = document.createElement('a')        a.href = url        a.download = fileName        a.click()      }      x.send()
    },123456789101112131415161718192021222324252627282930313233343536373839404142434445> 方法3:a标签下载
a标签html5版本新增了download属性,用来告诉浏览器下载该url,而不是导航到它,可以带属性值,用来作为保存文件时的文件名,尽管说有同源限制,但是我实际测试时非同源的也是可以下载的。
对于没有设置Content-Disposition响应头或者设置为inline的图片来说,因为图片对于浏览器来说是属于能打开的文件,所以并不会触发下载,而是直接打开,浏览器不能预览的文件无论有没有Content-Disposition头都会触发保存:其中:href是下载地址,download是下载名称;href 的下载地址 和 当前网站地址 必须是 同源的 ,否则download名称不生效。
<a href="../../static/demo.jpg" download="demo.jpg" target="_blank">demo.jpg</a>1<!-- 直接打开 --><a href="/test.jpg" download="test.jpg" target="_blank">jpg静态资源</a><!-- 触发保存 --><a href="/test.zip" download="test.pdf" target="_blank">zip静态资源</a><!-- 触发保存 --><a href="https://www.7-zip.org/a/7z1900-x64.exe" download="test.zip" target="_blank">三方exe静态资源</a><!-- 直接打开 --><a href="/createQrCode?text=http://lxqnsys.com/" download target="_blank">二维码流</a><!-- 直接打开 --><a href="/getFileStream?name=test.jpg" download target="_blank">jpg流</a><!-- 触发保存 --><a href="/getFileStream?name=test.zip" download target="_blank">zip流</a><!-- 触发保存 --><a href="/getAttachmentFileStream?name=test.jpg" download target="_blank">附件jpg流</a><!-- 触发保存 --><a href="/getAttachmentFileStream?name=test.zip" download target="_blank">附件zip流</a>12345678910111213141516方法4:a标签方式类似的还可以使用location.href
这2、3种方式的缺点也很明显,一是不支持post等其他方式的请求,二是需要后端支持
location.href = '/test.jpg'1还有其他的下载方式可以参考原文链接!————————————————版权声明:本文为CSDN博主「i_am_a_div_日积月累_」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/i_am_a_div/article/details/125050379
前端下载图片、pdf、excel、world文件;前端下载图片和pdf文件;前端a标签下载图片和pdf文件;下载文件名称不生效原因的更多相关文章
- c# 图片插入Excel
		
引用COM:Microsoft Office 11.0 Object Library 引用类: using System; using System.Windows.Forms; u ...
 - 如何使用JavaScript实现前端导入和导出excel文件
		
一.SpreadJS 简介 SpreadJS 是一款基于 HTML5 的纯 JavaScript 电子表格和网格功能控件,以“高速低耗.纯前端.零依赖”为产品特色,可嵌入任何操作系统,同时满足 .NE ...
 - 提高工作效率的神器:基于前端表格实现Chrome Excel扩展插件
		
Chrome插件,官方名称extensions(扩展程序):为了方便理解,以下都称为插件. 我们开发的插件需要在浏览器里面运行,打开浏览器,通过右上角的三个点(自定义及控制)-更多工具-拓展程序-打开 ...
 - angular2/angular4 如何通过$http的post方法请求下载二进制的Excel文件
		
时间有限,废话就不多说了,直接上干货! 下面给大家介绍一下我遇到的一个坑,如果你也遇到了,那恭喜你,你一定能找到答案:angular2/angular4 如何通过$http的post方法请求下载二进制 ...
 - ASP.NET Core 2.1以上 Bootstrap 4前端模板文件,开发环境与发布环境前端模板 environment的使用
		
笔者的前端文件如下 笔者增加Bootstrap 4 和 FontAwersome(字体图标),因为Bootsrap 4已经不再包含图标了. ASp.Net Core 中,通常在 _Layout.csh ...
 - 文件断点上传,html5实现前端,java实现服务器
		
断点上传能够防止意外情况导致上传一半的文件下次上传时还要从头下载,网上有很多关于断点的实现,这篇文章只是从前到后完整的记录下一个可用的实例,由于生产环境要求不高,而且就是提供给一两个人用,所以我简化了 ...
 - WordPress 前端投稿/编辑发表文章插件 DJD Site Post(支持游客和已注册用户)汉化版 免费下载
		
插件简介 前面逍遥乐给大家推荐了 WordPress用户前端化专业版WP User Frontend Pro WordPress中文汉化插件v2.1.9 今天逍遥乐给大家带来的wordpress插件是 ...
 - 导出带图片的Excel——OOXML文件分析
		
需求: 普通js导出文件excel具有兼容性问题,通过js-xsl导出文件API未找到导出图片的方案,实例过少,因此针对07年后以.xlsx后缀的excel文件,通过修改后缀.zip参考文件模板来实现 ...
 - JSP下载txt 和 Excel两种文件
		
JSP下载txt 和 Excel两种文件 jsp 下载txt文件和excel文件 jsp 下载txt文件和excel文件 最近做了个用jsp下载的页面 将代码贴出来 权作记录吧 1 下载txt文件 ...
 - Apache 后台服务器(主要处理php及一些功能请求 如:中文url)    Nginx 前端服务器(利用它占用系统资源少得优势来处理静态页面大量请求)    Lighttpd 图片服务器    总体来说,随着nginx功能得完善将使他成为今后web server得主流。
		
Apache 后台服务器(主要处理php及一些功能请求 如:中文url) Nginx 前端服务器(利用它占用系统资源少得优势来处理静态页面大量请求) Lighttpd 图片服务器 总体来说,随着ngi ...
 
随机推荐
- vue 组件之间传值(父传子,子传父)
			
1.父传子 基本就用一个方式,props Father.vue(用v-bind(简写 : ) 将父组件传的值绑定到子组件上) <template> <div> 我是爸爸:{{ ...
 - 痞子衡嵌入式:Farewell, 我的写博故事2022
			
-- 题图:苏州荷塘月色 2022 年的最后一天,写个年终总结.困扰大家三年之久的新冠疫情终于在 12 月全面放开了,痞子衡暂时还没有阳,计划坚持到总决赛.对于 2023 年,痞子衡还是充满期待的,慢 ...
 - Docker搭建Cloudreve网盘
			
原文地址: https://blog.laoda.de/archives/docker-compose-install-lighthouse-cloudreve 油管视频: https://www.y ...
 - [Leetcode]设计循环队列
			
题目 代码 class MyCircularQueue { public: /** Initialize your data structure here. Set the size of the ...
 - [WPF]数据绑定Demo
			
目录 1.View模型代码 2.ViewModel模型代码 3.数据模型 4.样例演示 5.一些知识点 这里简单实现一个listbox绑定的功能,符合MVVM模型. View模型代码(View视图以及 ...
 - 今天遇到的报错Babel noteThe code generator has deoptimised the styling of ...as it exceeds the max of 500KB.
			
解决办法如下: { test: /.js$/, exclude: /node_modules/, use: 'babel-loader' } 然并卵,我已经设置了这个东西了,突然发现我的文件并不在no ...
 - Vue34 VueX
			
1 简介 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 + 库.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. vue官方搭配,专属使用 ...
 - 【ASP.NET Core】标记帮助器——抽象层
			
标记帮助器,即 Tag Helpers.这个嘛,就直接翻译了,叫"标记帮助器",虽然不好听,但只能这样了.当然你翻译为"标记增强器"也行. 所谓标记帮助器,就是 ...
 - Zstack 鼎阳SDS6204示波器和Archiver Appliance的重度测试2
			
https://blog.csdn.net/weixin_43767046/article/details/113748775 https://blog.csdn.net/weixin_4376704 ...
 - LinkedList内部实现原理
			
LinkedList内部实现原理 java list 同ArrayList内部原理一样 我们先创建一个LinkedList对象LinkedList<String> li = new Lin ...