纯前端导出excel大数据导出

news/2024/7/21 3:51:09 标签: excel, 前端

需求

需求:客户数据量特别大,每天都有2w条以上的数据。 1、导出10w行*200列以上的数据 2、需要带样式导出 3、支持office 2007以上打开

方案一、excle.js

优点:不会有什么兼容性问题

缺点:3000*200以内的数据没有问题;超过就会出现性能问题,性能差的电脑就会出现浏览器崩溃 

 

方案二、xlxs.js + xlsx-js-style 、SheetJs等类似xlxs的js库

优点:不会有什么兼容性问题

缺点: 1、文件会比正常的文件会大3倍左右,每一个单元格大概多了32个字符串,

            2、跟方案一一样都会出现性能问题。

 

方案三、原生table导出

优点:速度非常快,10w*200列的数据,1分钟内导出。使用 拆分循 环封装一下封装数据大渲染模式,就可以解决性能问题。

关键点代码

// 数据触发拆分
function setXlsxData(parms){ // arr 行   headerList列 
    var s = 1000
    var sum = Math.ceil(parms.arr.length/s)
    var newObj={}
    for(var i= 0;i<sum;i++){
        (function(j) {
            setTimeout(function(){
                var sIn = j*s
                var endI = sIn+s
                if(j==sum-1&& parms.arr.length<s*sum){
                    endI = parms.arr.length
                }
                var newArr = parms.arr.slice(sIn,endI)
                newObj[j] = toForXlsxData(newArr,parms.headerList)
                checkDataOver(sum,newObj,parms,j)
            },j*200,)
        })(i);
    }   
}

// 拆分循环处理数据的逻辑
function toForXlsxData(arr,headerList){ 
    var newArr =[]
    for(var i = 0;i<arr.length;i++){
        var _itemRow = [];
        for(var k=0;k<headerList.length;k++){
            // _itemRow 每一个单元格数据处理 样式 等 
        }
        newArr.push(_itemRow)
    }
    return newArr
}

// 检查数据是否组装完成
function checkDataOver(sum,newObj,parms,j){
	// 导出进度等处理
	var status = Math.round((j/sum)*100)
    var statusText = "已导出进度"+ status + "%"
    if (sum === Object.keys(newObj).length) {
		// 组装数据完后的操作
    }
}

总结:小批量数据、所需数据已全部在页面可直接纯前端导出excel;大批量或需要逻辑的数据通过后端导出。


http://www.niftyadmin.cn/n/5415413.html

相关文章

代码随想录算法训练营第day40|343. 整数拆分 、 96.不同的二叉搜索树

a.343. 整数拆分 题目链接 给定一个正整数 n &#xff0c;将其拆分为 k 个 正整数 的和&#xff08; k > 2 &#xff09;&#xff0c;并使这些整数的乘积最大化。 返回 你可以获得的最大乘积 。 示例 1: 输入: n 2 输出: 1 解释: 2 1 1, 1 1 1。 示例 2: 输入: …

【深度学习模型】6_3 语言模型数据集

注&#xff1a;本文为《动手学深度学习》开源内容&#xff0c;部分标注了个人理解&#xff0c;仅为个人学习记录&#xff0c;无抄袭搬运意图 6.3 语言模型数据集&#xff08;周杰伦专辑歌词&#xff09; 本节将介绍如何预处理一个语言模型数据集&#xff0c;并将其转换成字符级…

‘ jupyter ‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。

安装anaconda后&#xff0c;在 Dos黑窗口 运行 jupyter notebook 的两个问题 原因&#xff1a;没配置环境变量 解决方法&#xff1a; 在 系统环境变量Path 中 添加两个地址 这里以anaconda安装在 D:\anaconda\install 下为例 &#xff08;根据个人安装具体位置而定&#xff…

自编码器(Autoencoder, AE)

自编码器(Autoencoder, AE)是一种无监督学习算法,它利用神经网络来学习数据的高效表示(即编码)。自编码器的目标是能够通过输入数据学习到一个压缩的、分布式的表示,然后通过这种表示重构出原始数据。自编码器主要由两部分组成:编码器(Encoder)和解码器(Decoder)。 …

SpringCloudFeign远程调用

文章目录 1. Feign 是什么2. Feign 的使用2.1 引入依赖2.2 写接口2.3 服务调用方2.4 启动测试 3. Feign 日志配置4. Feign 使用优化5. 注意包扫描问题6. 注意的问题6.1 参数问题6.2 Feign 自动装配 1. Feign 是什么 Feign 是一个声明式、模板化的 HTTP 客户端&#xff0c;它是…

菜鸟笔记-14散点图标记形状

大家在学习Python科研绘图中&#xff0c;总会涉及散点图标记形状&#xff0c;为了方便大家学习应用&#xff0c;博主通过学习搜集&#xff0c;将这部分技巧总结如下。 14.1默认散点图 14.1.1图像呈现 14.1.2绘图代码 import numpy as np # 导入numpy库&#xff0c;用于处理…

微信小程序开发系列(十五)·bind 绑定的事件(冒泡事件)、catch 绑定的事件(非冒泡事件)

目录 1. 事件分类 1.1 bind 绑定的事件&#xff08;冒泡事件&#xff09; 1.2 catch 绑定的事件&#xff08;非冒泡事件&#xff09; 1.3 代码 1. 事件分类 事件分为 冒泡事件 和 非冒泡事件&#xff1a; 冒泡事件&#xff1a;当一个组件的事件被触发后&#xff0c;…

【物联网设备端开发】Arduino IDE的ModbusRTU, ModbusTCP库

一、ModbusRTU, ModbusTCP and ModbusTCP Security 有关图书馆的使用详情&#xff0c;请查阅相关文档部分。 二、功能 支持所有Arduino平台在多个实例的任意组合中运行 Modbus RTU 主站Modbus RTU 从站Modbus TCP 主站 支持 ESP8266/ESP32 和 Ethernet libraryModbus TCP 从…