iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue中如何下载文件导出保存到本地
  • 342
分享到

vue中如何下载文件导出保存到本地

vue下载文件vue 导出文件vue文件导出保存到本地 2022-11-13 14:11:33 342人浏览 独家记忆
摘要

目录Vue下载文件导出保存到本地另一种情况vue中a标签下载本地文件-未找到,原因及解决错误代码原因解决vue下载文件导出保存到本地 先分析如何下载:先有一个链接地址,然后使用 lo

vue下载文件导出保存到本地

先分析如何下载:先有一个链接地址,然后使用 location.href或window.open()下载到本地

看看返回数据

res.config.url 中是下载链接地址,res.data 中是返回的二进制数据

如何下载

...
<el-button icon="el-icon-download" @click="download(id)"></el-button>
...
download(id) { // 导出
  this.$api({
    name: 'Download',
    paths: [id]
  }).then(res => {
    // window.open(res.config.url, '_self')或者
    window.location.href = res.config.url
  }).catch(error => {
    this.$message({ type: 'error', message: error })
  }).finally(() => {
  })
}

上面情况针对的是后端返回文件流,如果后端返回的是文件名

通用下载方法

window.location.href = baseURL + "/common/download?fileName=" + encodeURI(fileName) + "&delete=" + true

这样就能实现在当前窗口下载文件了

另一种情况

如果下载的文件既可以是txt文件或html文件也可以是压缩包等,对于这种类型的下载处理

    download (row) { // 下载
      this.$API({
        name: 'DownloadResource',
        params: {
          path: row.path,
          token: this.$Cookies.get('token')
        },
        headers: {
          'Content-Type': 'application/octet-stream'
        },
        requireAuth: true
      }).then (res => {
        window.open(`${res.config.url}?path=${res.config.params.path}&token=${res.config.params.token}`, '_self')
      }).catch(error => {
        this.$message.error(error)
      })
    }

对于 headers 中的 'Content-Type': 'application/octet-stream' ,需要在 axiOS 拦截器中单独处理 

建议把 res 打印出来看里面包含的内容

axios.interceptors.response.use(res => {
  // 处理下载文件的接口
  if (res.config.headers['Content-Type'] === 'application/octet-stream') {
    return res
  }
  if (res.data.code) {
    return Promise.resolve(res)
  } else {
    return Promise.reject(res)
  }
}, error => {
  return Promise.reject(error)
})

vue中a标签下载本地文件-未找到,原因及解决

错误代码

在vue项目中下载本地图片资源时失败并显示未找到,项目中代码为:

<a href="../../assets/bg.png" download="bg">
  <img src="../../assets/bg.png"></img>
</a>

原因

执行npm run serve 之后,在浏览器的调试工具下看a标签和img标签的代码为:

<a href="../../assets/bg.png" download="bg">
  <img src="/img/bg.png"></img>
</a>

会把图片资源放入/img文件下,也就是说上面的bg.png的在项目运行后真实路径为Http://localhost:8080/img/bg.jpg,故a标签的href有误,提示找不到文件,下载失败。

需要注意的是,如果图片大小小于4k,会直接把文件转为为base64文件,并放入CSS文件中,不会像上述图片一样,解析后放入/img下面。

解决

在href里面写npm run serve命令运行后的图片路径:

<a href="/img/bg.png" download="bg">
  <img src="../../assets/bg.png"></img>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。 

--结束END--

本文标题: vue中如何下载文件导出保存到本地

本文链接: https://www.lsjlt.com/news/171577.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • vue中如何下载文件导出保存到本地
    目录vue下载文件导出保存到本地另一种情况vue中a标签下载本地文件-未找到,原因及解决错误代码原因解决vue下载文件导出保存到本地 先分析如何下载:先有一个链接地址,然后使用 lo...
    99+
    2022-11-13
    vue下载文件 vue 导出文件 vue文件导出保存到本地
  • java中怎么下载文件流保存到本地
    在Java中,可以使用`InputStream`和`OutputStream`来下载文件流并保存到本地。下面的代码演示了如何使用`U...
    99+
    2023-09-05
    java
  • android下载文件保存到本地的方法是什么
    在Android中,可以使用以下代码将文件下载并保存到本地:1. 首先,需要在AndroidManifest.xml文件中添加以下权...
    99+
    2023-05-30
    android下载文件 android
  • java如何将hdfs文件下载到本地
    可以使用FileSystem类和FSDataInputStream类来实现将HDFS文件下载到本地。 import org.apac...
    99+
    2024-04-02
  • 如何实现mysql/mongo导出到本地文件
    这篇文章给大家分享的是有关如何实现mysql/mongo导出到本地文件的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 一. mongo导出到本地 ...
    99+
    2024-04-02
  • 小程序开发中如何保存文件到本地
    这篇文章主要为大家展示了小程序开发中如何保存文件到本地,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“小程序开发中如何保存文件到本地”这篇文章吧。保存文件到本地。注意:saveFile 会把临时文件...
    99+
    2023-06-26
  • java如何下载服务器文件到本地
    您可以使用Java的java.net.URL类和java.io.FileOutputStream类来下载服务器文件到本地。以下是一个...
    99+
    2024-04-09
    java
  • 如何下载文件到本地运行的vbs
    本篇内容介绍了“如何下载文件到本地运行的vbs”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!代码如下:'on error&...
    99+
    2023-06-09
  • java下载文件到本地代码如何写
    以下是一个简单的Java代码示例,用于从指定的URL下载文件到本地: import java.io.FileOutputStream...
    99+
    2024-04-02
  • python从下载链接下载文件到本地
    requests #引用 requests文件 import requests #下载地址 Download_addres='https://nj02cm01.baidupcs.com/file/da941ce26b392a4...
    99+
    2023-01-31
    下载链接 文件 python
  • hadoop怎么下载文件到本地
    可以使用以下命令将Hadoop集群中的文件下载到本地: hadoop fs -get <HDFS文件路径> <本地...
    99+
    2024-03-02
    hadoop
  • adb logcat 保存日志文件到本地
    指令 adb logcat > logcat.log 例如:例如:adb logcat > D:\logcat.log 注意window中直接输入可能会出现log文件打开显示乱码问题; 请打开cmd检...
    99+
    2023-10-09
    adb android
  • vue如何加载本地json文件
    这篇“vue如何加载本地json文件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue如何加载本地json文件”文章吧。整...
    99+
    2023-07-04
  • php如何实现保存下载文件
    这篇文章主要介绍“php如何实现保存下载文件”,在日常操作中,相信很多人在php如何实现保存下载文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php如何实现保存下载文件”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-20
  • teraterm如何保存log到本地
    要将日志保存到本地,可以按照以下步骤进行操作:1. 打开 Tera Term 软件。2. 连接到目标设备或主机。3. 在 Tera ...
    99+
    2023-08-24
    teraterm
  • php怎么下载大文件到本地
    要下载大文件到本地,可以使用PHP的`file_get_contents()`函数结合`file_put_contents()`函数...
    99+
    2023-10-30
    php
  • Vue如何下载本地静态资源static文件夹
    目录下载本地静态资源static文件夹下载静态文件方法下载下载本地static静态文件的踩坑下载本地静态资源static文件夹 下载静态文件方法 <a href="/stat...
    99+
    2024-04-02
  • php中如何下载pdf转存本地
    小编给大家分享一下php中如何下载pdf转存本地,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!php下载pdf转存本地的实现方法:首先创建html页面代码以及sc...
    99+
    2023-06-15
  • vue使用file-saver本地文件导出功能
    1:安装xlsx和file-saver npm install file-saver xlsx  --save 2:创建localExports.js文件 3:直接上代码 ...
    99+
    2024-04-02
  • Android应用中如何异步下载图片并将图片保存到本地DEMO中
    Android应用中如何异步下载图片并将图片保存到本地DEMO中?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。通下面是demo中的Activity。public class...
    99+
    2023-05-31
    android roi
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作