我的编程空间,编程开发者的网络收藏夹
学习永远不晚

浅谈vue中文件下载的几种方式及方法封装

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

浅谈vue中文件下载的几种方式及方法封装

一、通过对后端发送post请求,使用blob下载文件


function downBlob(res, fileName = "导出报表", format = "xlsx") {
  // 调用接口获取到文件
  const blob = new Blob([res], {
    type: "application/vnd.ms-excel"
  });
  // 下载文件名
  fileName = fileName + parseInt(Math.random() * 9999) + "." + format;
  const linkNode = document.createElement("a");

  linkNode.download = fileName; // a标签的download属性规定下载文件的名称
  linkNode.style.display = "none";
  linkNode.href = URL.createObjectURL(blob); // 生成一个Blob URL
  document.body.appendChild(linkNode);
  linkNode.click(); // 模拟在按钮上的一次鼠标单击

  URL.revokeObjectURL(linkNode.href); // 释放URL 对象
  document.body.removeChild(linkNode);
}

二、通过对后端发送post请求,使用url下载文件


function download(fileName, url) {
  fileName = fileName || "导出报表";
  let arr = url.split(".");
  fileName += parseInt(Math.random() * 9999) + "." + arr[arr.length - 1];
  const linkNode = document.createElement("a");
  linkNode.download = fileName; // a标签的download属性规定下载文件的名称
  linkNode.style.display = "none";
  if (process.env.VUE_APP_TEM_PATH) {
    // 生成一个Blob URL
    linkNode.href = process.env.VUE_APP_TEM_PATH + url;
  } else {
    // 生成一个Blob URL
    linkNode.href = url;
  }
  document.body.appendChild(linkNode);
  linkNode.click(); // 模拟在按钮上的一次鼠标单击
  URL.revokeObjectURL(linkNode.href); // 释放URL 对象
  document.body.removeChild(linkNode);
}

进行main.js中全局引用

// 通过url下载文件
import { download } from "@/utils/auth";
Vue.prototype.$download = download;

// 通过blob下载文件
import { downBlob } from "@/utils/auth";
Vue.prototype.$downBlob = downBlob;

实际使用方式

// res.data.url 通过url下载文件
this.$download("销售统计", res.data.url);

// res 通过blob下载文件
this.$downBlob(res, "商城订单与ERP订单对照明细");

到此这篇关于浅谈vue中文件下载的几种方式及方法封装的文章就介绍到这了,更多相关vue 文件下载内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

浅谈vue中文件下载的几种方式及方法封装

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

浅谈vue中文件下载的几种方式及方法封装

本文主要介绍了浅谈vue中文件下载的几种方式及方法封装,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-13

VUE+ElementUI下载文件的几种方式(小结)

本文主要介绍了VUE+ElementUI下载文件的几种方式(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-13

vue关于下载文件常用的几种方式

这篇文章主要介绍了vue关于下载文件常用的几种方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

前端vue中实现文件下载的几种方法总结

这篇文章主要介绍了前端vue中实现文件下载的几种方法总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-05-15

python下载文件的几种常用方法

python中下载文件常用的几个模块有urllib,urllib2,requests,方法也很简单,代码如下:# Python 2 codeimport urllibimport urllib2import requests        
2023-01-31

vue下载文件及文件重命名的方法是什么

这篇文章主要介绍“vue下载文件及文件重命名的方法是什么”,在日常操作中,相信很多人在vue下载文件及文件重命名的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue下载文件及文件重命名的方法是什么
2023-07-04

Java 从网上下载文件的几种方式实例代码详解

废话不多说了,直接给大家贴代码了,具体代码如下所示;package com.github.pandafang.tool;import java.io.BufferedOutputStream;import java.io.File;impo
2023-05-31

Vue中导入excel文件的两种方式及使用步骤

这篇文章主要介绍了Vue中导入excel文件的两种方式,大概有两种导入文件的方法:form表单和el-upload,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-22

vue2文件流下载成功后文件格式错误、打不开及内容缺失的解决方法

使用Vue时我们前端如何处理后端返回的文件流,下面这篇文章主要给大家介绍了关于vue2文件流下载成功后文件格式错误、打不开及内容缺失的解决方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2023-05-18

win8系统如何破解rar加密文件?win8系统下载rar格式的压缩软件有密码的三种破解方法

Win8系统从网上下载程序软件,发现是rar格式的压缩软件,并且设置了密码,根本打不开,怎么办呢?其实这类压缩软件中自带了密码,只是很多用户不知道而已,那么有什么办法能够破解密码呢?根据这个问题,小编研究整理出下面破解方法,感兴趣的用户一起
2022-06-04

编程热搜

目录