纯前端倒出excel,大数据导出

需求

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

尝试过的方案

方案一、excle.js

复制代码
优点:不会有什么兼容性问题
缺点:3000*200以内的数据没有问题;超过就会出现性能问题,性能差的电脑就会出现浏览器崩溃
性能原因:形成xlsx文件的写入方法问题,需要使用 拆分循环 修改形成文件源码,跪求大佬修改一下给小弟学习。

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

复制代码
优点:不会有什么兼容性问题
缺点:
1、文件会比正常的文件会大3倍左右,每一个单元格大概多了32个字符串,
2、跟方案一一样都会出现性能问题
性能原因:形成xlsx文件的写入方法问题,需要使用 拆分循环 修改形成文件源码,跪求大佬修改一下给小弟学习。

方案三、原生table导出

复制代码
优点:速度非常快,10w*200列的数据,1分钟内导出。使用 拆分循 环封装一下封装数据大渲染模式,就可以解决性能问题。
缺点:
1、office2007以上打开会有告警,但是数据内容是正常的
2、苹果手机 微信打开 文件空白
3、下载的文件,本地编辑插入不了图片

最终方案

使用方案三,客户可以接受其的三个兼容性问题

关键点代码

shell 复制代码
#### 陈年老项目,不能写ES6,那就将就的使用吧
ini 复制代码
// 数据触发拆分
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) {
		// 组装数据完后的操作
    }
}
相关推荐
未来之窗软件服务33 分钟前
一体化系统(九)智慧社区综合报表——东方仙盟练气期
大数据·前端·仙盟创梦ide·东方仙盟·东方仙盟一体化
陈天伟教授4 小时前
人工智能训练师认证教程(2)Python os入门教程
前端·数据库·python
信看4 小时前
NMEA-GNSS-RTK 定位html小工具
前端·javascript·html
Tony Bai5 小时前
【API 设计之道】04 字段掩码模式:让前端决定后端返回什么
前端
苏打水com5 小时前
第十四篇:Day40-42 前端架构设计入门——从“功能实现”到“架构思维”(对标职场“大型项目架构”需求)
前端·架构
king王一帅5 小时前
流式渲染 Incremark、ant-design-x markdown、streammarkdown-vue 全流程方案对比
前端·javascript·人工智能
苏打水com5 小时前
第十八篇:Day52-54 前端跨端开发进阶——从“多端适配”到“跨端统一”(对标职场“全栈化”需求)
前端
Bigger5 小时前
后端拒写接口?前端硬核自救:纯前端实现静态资源下载全链路解析
前端·浏览器·vite
BD_Marathon6 小时前
【JavaWeb】路径问题_前端绝对路径问题
前端