vue使用asiox 下载后端返回的excel数据流

一、前端代码

javascript 复制代码
<template>
  <div class="hello">
    <h1>{{ msg }}</h1>
    <button style="color: brown" @click="exportExcel">excel导出</button>
  </div>
</template>

<script>
import axios from "axios";

export default {
  name: "HelloWorld",
  props: {
    msg: String,
  },
  methods: {
    exportExcel() {
      //请求
      console.log("test");
      axios
        .post("/api/export", {}, { responseType: "blob" })
        .then((res) => {
          //请求成功,触发then中的函数
          console.log(res);
          const blob = new Blob([res.data], {
            type: "application/vnd.ms-excel",
          });

          // 获取 获取响应头 heads 中的 filename 文件名
          let temp = res.headers["content-disposition"]
            .split(";")[1]
            .split("filename=")[1];
          // 把 %E9%AB%98%E6%84%8F%E5%90%91%E5%AD%A6%E5%91%98303.xlsx 转化成文字
          var fileName = decodeURIComponent(temp);
          //创建一个 a 标签
          const link = document.createElement("a");
          //不显示a标签
          link.style.display = "none";
          // 给a 标签的href属性赋值
          link.href = URL.createObjectURL(blob);
          link.setAttribute("download", fileName);
          //把a标签插入页面中
          document.body.appendChild(link);
          link.click();
          //点击之后移除a标签
          document.body.removeChild(link);
        })
        .catch((error) =>
          //请求失败,触发catch中的函数 可省略
          console.log(error)
        );
    },
  },
};
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
h3 {
  margin: 40px 0 0;
}
ul {
  list-style-type: none;
  padding: 0;
}
li {
  display: inline-block;
  margin: 0 10px;
}
a {
  color: #42b983;
}
</style>

二、后端代码

java 复制代码
    @PostMapping("/export")
    public void download(HttpServletResponse response) throws IOException {
        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
        response.setCharacterEncoding("utf-8");
        // 这里URLEncoder.encode可以防止中文乱码
        String fileName = URLEncoder.encode("交付对象及机构信息关系表", "UTF-8").replaceAll("\\+", "%20");
        response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
        //自行编写查询数据库数据
        List<DataOrganizationDrugRelationExport> list = Lists.newArrayList();
        EasyExcel.write(response.getOutputStream(), DataOrganizationDrugRelationExport.class).head(DataOrganizationDrugRelationHeader.class).sheet("结果").doWrite(list);
    }
相关推荐
鹏北海6 分钟前
micro-app 微前端项目部署指南
前端·nginx·微服务
发现一只大呆瓜9 分钟前
虚拟列表:从定高到动态高度的 Vue 3 & React 满分实现
前端·vue.js·react.js
css趣多多12 分钟前
add组件增删改的表单处理
java·服务器·前端
证榜样呀18 分钟前
2026 大专计算机专业必考证书推荐什么
大数据·前端
蓝帆傲亦25 分钟前
前端性能极速优化完全指南:从加载秒开体验到丝滑交互
前端·交互
鱼毓屿御37 分钟前
如何给用户添加权限
前端·javascript·vue.js
JustHappy41 分钟前
「web extensions🛠️」有关浏览器扩展,开发前你需要知道一些......
前端·javascript·开源
何中应1 小时前
nvm安装使用
前端·node.js·开发工具
Java新手村1 小时前
基于 Vue 3 + Spring Boot 3 的 AI 面试辅助系统:实时语音识别 + 大模型智能回答
vue.js·人工智能·spring boot
雯0609~1 小时前
hiprint:实现项目部署与打印3-vue版本-独立出模板设计与模板打印页面
前端·vue.js·arcgis