首页 > 其他分享 >easyExcel导出大数据量EXCEL文件,前端实现进度条

easyExcel导出大数据量EXCEL文件,前端实现进度条

时间:2024-09-19 16:52:31浏览次数:12  
标签:进度条 easyExcel 导出 event xhr 数据量 var response

需求:页面点击导出,先按照页面条件去数据库查询,然后将查询到的数据导出。

问题:由于查询特别耗时,所以点击之后页面会看上去没有反应,就在点击之后在页面增加了一个进度条,等待后盾查询结束之后,导出时,进度条会显示导出进度,导出结束之后进度条会消失。效果如下:

注意点:后端需要在响应头中设置ContentLength,前端需要用这个更新进度

response.setContentLength(excelBytes.length); // 设置Content-Length

html代码:

<button type="button" id="export_btn" class="layui-btn btn_blue">导 出</button>
<!-- 进度条容器 -->
<div id="progressContainer" style="display:none; margin-top:20px;">
    <div id="progressBar"></div>
</div>

<!-- 显示下载进度百分比 -->
<div id="progressText" style="display:none; margin-top:5px;">下载进度: 0%</div>

css:

#progressContainer {
    width: 100%;
    background-color: #f3f3f3;
    border: 1px solid #ccc;
    border-radius: 5px;
}
#progressBar {
    width: 0%;
    height: 20px;
    background-color: #4caf50;
    border-radius: 5px;
}

js代码:

// 进度条
$('#export_btn').on('click', function () {
    // 获取表单数据
    var formData = $('#searchForm').serializeArray();
    var params = {};
    $.each(formData, function () {
        params[this.name] = this.value;
    });
    params['publishFrom'] = '${RequestParameters.type}';

    // 构建查询字符串
    var queryString = $.param(params);

    // 创建XHR对象
    var xhr = new XMLHttpRequest();
    xhr.open('POST', '路径/exportData', true);
    xhr.responseType = 'blob'; // 设置响应类型为blob

    // 显示进度条
    $('#progressContainer').show();
    $('#progressText').show();
    $('#progressBar').css('width', '0%');
    $('#progressText').text('下载进度: 0%');

    // 设置请求头以模拟表单提交
    // xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');

    // 监听下载进度
    xhr.onprogress = function (event) {
        if (event.lengthComputable) {
            var percentComplete = Math.round((event.loaded / event.total) * 100);
            console.log('Loaded:', event.loaded, 'Total:', event.total);
            $('#progressBar').css('width', percentComplete + '%');
            $('#progressText').text('下载进度: ' + percentComplete + '%');
        } else {
            console.log('无法计算进度');
        }
    };

    // 下载完成后处理
    xhr.onload = function () {
        if (xhr.status === 200) {
            // 隐藏进度条
            $('#progressContainer').hide();
            $('#progressText').hide();

            // 创建下载链接并触发下载
            var blob = xhr.response;
            var downloadUrl = URL.createObjectURL(blob);
            var a = document.createElement('a');
            a.href = downloadUrl;
            // 从响应头中获取文件名
            var disposition = xhr.getResponseHeader('Content-Disposition');
            var fileName = '下载文件.xlsx';
            if (disposition && disposition.indexOf('filename*=utf-8\'\'') !== -1) {
                var filenameRegex = /filename\*=utf-8''(.+)/;
                var matches = filenameRegex.exec(disposition);
                if (matches != null && matches[1]) {
                    fileName = decodeURIComponent(matches[1]);
                }
            }
            a.download = fileName;
            document.body.appendChild(a);
            a.click();
            document.body.removeChild(a);
            URL.revokeObjectURL(downloadUrl);
        } else {
            alert('下载失败,请重试。');
            $('#progressContainer').hide();
            $('#progressText').hide();
        }
    };

    // 发送请求
    xhr.send(queryString);
});

后端代码,使用easyExcel导出

//数据查询
List<Sell> sellList = this.search();

// 将Excel写入ByteArrayOutputStream
try (ByteArrayOutputStream baos = new ByteArrayOutputStream()) {
    // 使用EasyExcel将数据写入ByteArrayOutputStream
    EasyExcel.write(baos, Sell.class)
            .sheet("列表")
            .doWrite(sellList);

    // 获取Excel字节数组
    byte[] excelBytes = baos.toByteArray();

    // 设置响应头
    response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
    response.setCharacterEncoding("utf-8");
    String fileName = URLEncoder.encode("列表导出_Sell", "UTF-8").replaceAll("\\+", "%20");
    response.setHeader("Content-Disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
    response.setHeader("Cache-Control", "max-age=0");
    response.setContentLength(excelBytes.length); // 设置Content-Length

    // 将Excel字节数组写入响应
    try (OutputStream out = response.getOutputStream()) {
        out.write(excelBytes);
        out.flush();
    }

} catch (IOException e) {
    e.printStackTrace();
}

 

标签:进度条,easyExcel,导出,event,xhr,数据量,var,response
From: https://blog.csdn.net/weixin_42285408/article/details/142363872

相关文章

  • 简单文本进度条案例
    python用PyCharm软件文本进度条进度条一般以图形的方式显示已完成任务量和未完成任务量,并以动态文字的方式显示任务的完成度。实例目标通过完成本实例,读者应掌握以下知识或技能:熟练使用format()方法格式化字符串。了解time模块中sleep()函数的用法实例分析本实例要实......
  • Elment Plus数据展示 | Progress进度条(超详细!)
            用于展示操作进度,告知用户当前状态和预期。一、直线进度条        Progress组件设置 percentage 属性即可,表示进度条对应的百分比。该属性必填,并且必须在 0-100 的范围内。你可以通过设置 format 来自定义文字显示的格式。     运行......
  • EasyExcelUtil导出
    packagecom.istrong.seatom.utils;importcn.hutool.core.collection.ListUtil;importcom.alibaba.excel.EasyExcel;importcom.alibaba.excel.enums.CellDataTypeEnum;importcom.alibaba.excel.metadata.Head;importcom.alibaba.excel.metadata.data.WriteCellData......
  • 视频数据量怎么计算需要多少带宽
    视频数据量的计算以及所需带宽的估算涉及多个因素。以下是计算视频数据量和估算所需带宽的一般步骤:视频数据量计算确定视频参数:分辨率:视频的宽度和高度,例如1920x1080。帧率:每秒显示的帧数,例如30fps(帧每秒)。像素深度:每个像素使用的位数,例如24位(RGB各8位)。视频时长:视频的长度,以秒或分......
  • 进度条效果
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><title>ProgressBar</title>......
  • c#进度条实现方法
    在使用c#做WinFrom开发时,经常会用到进度条(ProgressBar)。那么如何才能实现winfrom进度条及进度信息提示呢?方法一:多线程使用c#做WinFrom开发,要实现进度条效果就需要用到多线程,如果不采用多线程控制进度条,窗口很容易假死(无法适时看到进度信息)1、设计界面需要引用usingSys......
  • 【2024年Python量化分析】为股票数据量化分析最新整理的免费获取股票实时行情数据API
    ​最近一两年,股票量化分析越来越火了,想入门这行,首先得搞定股票数据。毕竟,所有量化分析都是靠数据说话的,实时交易、历史交易、财务、基本面,这些数据咱们都得有。咱们的目标就是把这些数据里的金子挖出来,指导咱们的投资策略。​为了找数据,我可是没少折腾,自己动手写过网易、......
  • 【redis】数据量庞大时的应对策略
    文章目录为什么数据量多了主机会崩分布式系统应用数据分离架构应用服务集群架构负载均衡器数据库读写分离引入缓存冷热分离架构分库分表微服务是什么代价优势为什么数据量多了主机会崩一台主机的硬件资源是有上限的,包括但不限于一下几种:CPU内存硬盘网络…服务器......
  • 界面控件KendoReact中文教程 - 如何创建动态进度条?
    KendoUI致力于新的开发,来满足不断变化的需求。现在我们非常自豪地宣布,通过React框架的KendoUIJavaScript封装来支持ReactJavascript框架。KendoUIforReact能够为客户提供更好的用户体验,并且能够更快地构建更好的应用程序。KendoReact2024Q2新版下载进度条是重要的UI元......
  • 界面控件KendoReact中文教程 - 如何创建动态进度条?
    KendoUI致力于新的开发,来满足不断变化的需求。现在我们非常自豪地宣布,通过React框架的KendoUIJavaScript封装来支持ReactJavascript框架。KendoUIforReact能够为客户提供更好的用户体验,并且能够更快地构建更好的应用程序。KendoReact2024Q2新版下载进度条是重要的UI......