vue 本地pdf或excel等文件下载
目录
1.需求确定
2.具体内容
3.总结
1.需求确定
最近在项目中要点击“帮助文档”,下载《系统操作手册》。
也就是获取静态资源文件export.pdf,将pdf文档下载至本地。
拿到这个需求后,找了些方案,如下
方案1:在vue cli中安装一些插件,如jquery,利用jquery下载本地文件;
方案2:直接使用原生ajax下载本地文件;
方案3:利用axios请求;
最后考虑到项目中已经在使用axios,就采用方案3。
2.具体内容
在使用过程中发现问题记录如下:
项目1:vue 2.0 + element ui+es5中
利用a标签,给个点击事件download()
<a id="attname" class="attname" href="javascript:void(0);" @click="download">帮助文档
页面已经引用过axios,使用如下:
import axios from 'axios';
Download方法中为避免无法导出,将待导出文件名称改为英文“export.pdf”,导出后的名称设置为中文名称“系统操作手册.pdf”;
待导出文件放在“static”文件夹下;
download(){
axios.get('static/export.pdf', {
responseType: 'blob', //重要
}).then(response => {
const url = window.URL.createObjectURL(new Blob([response.data]));
const link = document.createElement('a');
let fname = '系统操作手册.pdf';
link.href = url;
link.setAttribute('download', fname);
document.body.appendChild(link);
link.click();
});
}
项目2:vue 3.0 + iview ui+typescript中
利用a标签,给个点击事件download()
<a id="attname" class="attname" href="javascript:void(0);" @click="download">帮助文档
页面已经引用过axios
import axios from 'axios';
Download方法中为避免无法导出,将待导出文件名称改为英文“export.pdf”,导出后的名称设置为中文名称“系统操作手册.pdf”;
在“public”文件夹下建“export”文件夹,放待导出文件;
download(){
axios.get('export/export.pdf', {
responseType: 'blob', //重要
}).then(response => {
const url = window.URL.createObjectURL(new Blob([response.data]));
const link = document.createElement('a');
let fname = '系统操作手册.pdf';
link.href = url;
link.setAttribute('download', fname);
document.body.appendChild(link);
link.click();
});
}
其中,在项目2的使用过程中遇到了问题,将待下载文件放在“static”或“assets”文件夹下,始终获取不到待下载文件,不同的后缀的文件“.json、.ts”等都是404找不到,如下:
经过一天的问题查找,发现vue cli3.0中静态资源文件夹为“public”,在“public”文件夹下建“export”文件夹,放待导出文件“export.pdf”后,返回状态码200,下载正常:
3.总结
vue cli2.0的静态文件是static
vue cli3.0的静态文件是public
童鞋们使用过程中千万不要搞错了,会获取不到本地文件的
注:除本文中pdf文件外,还可下载其他格式为文件,使用方式类似;
记录一下,以备查询使用;
vue 本地pdf或excel等文件下载的更多相关文章
- vue+iview 通过a标签实现文件下载
vue+iview 通过a标签实现文件下载 方法一: 注意: 如果下载的文件放在本地目录下,一定要将模板文件放到 public 目录下,否则由于权限问题找不到文件 路径: 项目更目录-->pub ...
- PDF/WORD/EXCEL 图片预览
一.PDF/WORD/EXCEL 转 XPS 转 第一页内容 转 图片 WORD.EXCEL转XPS (Office2010) public bool WordToXPS(string sourceP ...
- vue实现pdf导出,解决生成canvas模糊等问题
最近公司项目需要,利用vue实现pdf导出,从而保存到本地打印出来,说起来好像也很容易,具体要怎么实现呢? 1 .我们要添加两个模块 第一个.将页面html转换成图片 npm install --sa ...
- C#下载http/https的pdf、excel等文件(非在线打开,绕开插件)
非本服务器文件,如PDF,excel等,下载一般是通过href=‘远程文件的http或者https’的方式下载,但是如果浏览器已经有PDF插件了,则用href不是下载,而是在线打开了,影响体验,所以远 ...
- C# 将PDF转为Excel
通常,PDF格式的文档能支持的编辑功能不如office文档多,针对PDF文档里面有表格数据的,如果想要编辑表格里面的数据,可以将该PDF文档转为Excel格式,然后编辑.本文,将以C#代码为例,介绍如 ...
- C#/VB.NET 将PDF转为Excel
PDF文档可以避免可防⽌他⼈⽆意中触到键盘修改⽂件内容.但是在避免他人⽆意修改的同时也妨碍了正常的修改.如果你想处理或修改PDF文档中的数据,不妨试试用Excel来实现.Excel拥有强大的数据处理功 ...
- Vue中实现自定义excel下载
目录 第一种:后端生成excel 第二种:前端合成excel 总结 参考资料 最近在工作中遇到一个需求,就是需要在前端实现一个错误模板Excel的下载功能. 实现下载有两种方式,一种是后端生成一个ex ...
- ABBYY如何把PDF转换Excel
我们都知道2007以上版本的Office文档,是可以直接将文档转存为PDF格式文档的.那么反过来,PDF文档可以转换成其他格式的文档吗?这是大家都比较好奇的话题.如果可以以其他格式进行保存,就可以极大 ...
- Ireport 报表导出 Poi + ireport 导出pdf, word ,excel ,htm
Ireport 报表导出 Poi + ireport 导出pdf, doc ,excel ,html 格式 下面是报表导出工具类reportExportUtils 需要导出以上格式的报表 只需要调用本 ...
- springboot为导出的pdf和excel加水印
相信很多小伙伴们在做导出pdf或者excel文件时会被要求在文件上加上水印,本篇博客就来讲讲如何为pdf和excel加水印. 导出pdf加水印 其实在导出pdf时加上水印并不难,因为itext提供了添 ...
随机推荐
- react项目vite报错:UnhandledPromiseRejectionWarning: SyntaxError: Unexpected token '??='
问题: vite报错:UnhandledPromiseRejectionWarning: SyntaxError: Unexpected token '??=' 今天clone一个vite的项目,安装 ...
- 亚马逊aws_access_key_id和aws_secret_access_key利用
00X01 信息泄露 敏感信息泄露,例如环境变量.例如,为了配置AWS CLI,需要设置以下环境变量: $ export AWS_ACCESS_KEY_ID=AKISIOSFODNN7EXAMPLE ...
- 聊聊@Autowired与@Resource的区别
1. 前言 从事过很多家公司,见过很多项目,发现@Autowired和@Resource的使用都是一样的乱, 一个项目中有使用@Autowired的,有使用@Resource的, 甚至有的类中一会儿使 ...
- heapdump敏感信息提取工具-JDumpSpider(一) ,附下载链接
介绍 HeapDump敏感信息提取工具 在日常得渗透测试工作中,经常遇到spring actuator未授权漏洞,而且在实际过程中也常常会下载到heapdump这个文件.了解过这个文件的人知道,H ...
- 如何开启AI副业,月入10w? 想听的速来!!
提供AI咨询+AI项目陪跑服务,有需要回复1 最近几天与粉丝多有交流,他们或者是经理.或者是总监,甚至有粉丝手里已经掌握了公司一些预算使用权. 从他们身上反映出了同一个问题:他们对于AI是偏焦虑的,想 ...
- 赛前十天——递归(easy)
*理论上,递归与循环是等价的,即任何循环都可以重写为递归形式 eg: package javaPractice; public class Contest { public stati ...
- python3里面比较两个字符串的不同【difflib】
一.difflib库的用法 a = '/Users/melon/Desktop/odoo14/myaddons/watermark_design/fonts/SimSun.ttf' b = '/Use ...
- The length of parametric curve (x + sin x, cos x)
问题引入 一个硬币(圆)的周长上有一个点,将硬币在一条线上无滑动地滚动.假设那个点开始时在最上面,滚了半圈到了最下面,求这个点相对于地面的运动轨迹的长度. 或者说,再简单点,自行车总骑过吧.假如你在骑 ...
- C#/.NET/.NET Core优秀项目和框架2025年5月简报
前言 公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架(每周至少会推荐两个优秀的项目和框架当然节假日除外),公众号推文中有项目和框架的详细介绍.功能特点.使用方式以及部分功能 ...
- Permutation Counting
\(n\) 的范围很小,考虑动态规划. \(f_{i,j}\) 在前 \(i\) 个数有 \(j\) 个 \(<\) 的个数. 若 \(\texttt {a<b<c<d}\), ...