Vue+Java的EXCEL导出解决方案,供参考

JAVA端

控制器层

    @PostMapping(value = "/export")
    public void exportGraphTemplate(HttpServletResponse response) {
        try {
            @Cleanup ExcelWriter writer = exportService.exportTemplate();
            response.setContentType("application/vnd.ms-excel");
            response.setCharacterEncoding("utf-8");
            response.setHeader("Content-Disposition", "attachment;filename=".concat(String.valueOf(URLEncoder.encode(StrUtil.format("{}.xls", DateUtil.now()), CharsetUtil.UTF_8))));
            @Cleanup ServletOutputStream outputStream = response.getOutputStream();
            writer.flush(outputStream, true);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

服务层

    public ExcelWriter exportTemplate() {
        
        ExcelWriter writer = ExcelUtil.getWriter();
        
        try {

            List<String> header = new ArrayList<>();
            header.add("表头1");
            header.add("表头2");
            header.add("表头3");
             
            writer.writeHeadRow(header);

            List<List<String>> content = new ArrayList<>();
            for(int i=0;i<5;i++) {
                List<String> co = new ArrayList<>();
                co.add("内容1");
                co.add("内容2");
                co.add("内容3");
                content.add(co);
            }

            writer.write(content);
            
            
        } catch (Exception e) {
            e.printStackTrace();
        }
        
        return writer;
    }

前端

return request({
        url: '/export',
        method: 'post',
        data: {},
        responseType: "blob",
      }).then(
          response => {
            let fileName = '文件名称.xls'
            const link = document.createElement('a')
            const blob = new Blob([response.data], { type: 'application/vnd.ms-excel' })
            link.style.display = 'none'
            link.href = URL.createObjectURL(blob)
            link.setAttribute('download', `${decodeURIComponent(fileName)}`)
            document.body.appendChild(link)
            link.click()
            document.body.removeChild(link)
          },
          error => {
          }
      )

 

 

 

 

posted @ 2022-03-18 12:09  wxxwjef  阅读(731)  评论(0编辑  收藏  举报