vue下载excel表格

下载excel表格

先从后端获取文件流,获取数据为blob格式,然后创建a窗口,命名要下载的文件,最后移除a标签

代码如下:

javascript 复制代码
downLoad() {
   let params = {
        model_name: "a"
      }
   this.$axios
      .get(`url`, { responseType: "blob", params})
      .then((res) => {
          console.log(res.data)
          const link = document.createElement("a");
          let blob = new Blob([res.data], {
            type: "application/xlsx,charset=utf-8",
          });
          link.style.display = "none";
          link.href = URL.createObjectURL(blob);
          // 默认下载时的名称及后缀
          link.download = 'xxx' + ".xlsx";
          document.body.appendChild(link);
          //模拟点击事件
          link.click();
          //移除创建的a标签
          window.URL.revokeObjectURL(link.href);
          document.body.removeChild(link);
        });
}
相关推荐
「已注销」34 分钟前
面试分享:二本靠7轮面试成功拿下大厂P6
前端·javascript·面试
walking9571 小时前
重新学习前端之JavaScript
前端·vue.js·面试
walking9571 小时前
重新学习前端之HTML
前端·vue.js·面试
walking9571 小时前
重新学习前端之Vue
前端·vue.js·面试
泉城老铁1 小时前
springboot实现word转换pdf
vue.js·后端
walking9571 小时前
重新学习前端之设计模式与架构
前端·javascript·面试
walking9571 小时前
重新学习前端之TypeScript
前端·javascript·面试
walking9571 小时前
重新学习前端之Linux
前端·vue.js·面试
walking9571 小时前
重新学习前端之CSS
前端·vue.js·面试
walking9571 小时前
重新学习前端之Git
前端·vue.js·面试