通过一个已有的excel文件,在页面上实现一个在线的支持编辑和导出的excel编辑器

一、前景

怎么快速直接通过一个已有的excel文件,在页面上实现一个在线的支持编辑和导出的excel呢

二、具体实现

利用luckysheet和luckyExcel 俩个开源并且很强大的excel库即可快速实现

简介:luckyExcel是一个适配 Luckysheet 的excel导入导出库,可以将excel文件转化为luckySheet能够识别的格式, Luckysheet是一个可以支持配置并生成在线excel的库。

luckysheet:Luckysheet文档 (gitee.io)--具体配置可去官网查看 支持生成多sheet的excel并且支持单元格内容宽高等一系列excel设置,是一个富文本编辑器

具体代码:

1 luckysheet 快速生成一个在线excel

其中最重要的是data配置 称之为 工作表配置 Array<>

一项代表生成一个sheet页--储存着单元格等一系列内容

进行了如上配置后 进行初始化操作 咱就可以得到一个在线的自定义excel编辑器

效果如下

如果手动进行data的传入,这样耗时是非常多的 所以我们可以采用下面的方法 将一份excel数据转化为luckysheet能识别的data

2 excel文件转化为luckysheet格式--luckyexcel

利用上述代码 我们可以自己导入一个excel二进制,转化为luckysheet形式的data--上述excel效果就是这样生成的-----

痛点:官方转化存在一个bug,不能将excel的数据校验同步出来目前,需要修改底层方法--或者我们手动通过 setDataVerificatio方法 或者 直接在excel上设置数据验证

小提示:

(1) 咱针对一份excel 导出的data我们是可以保存为静态json的 并不需要每次都导入

(2) 咱对excel如果需要进行单元格宽度加宽等变更操作时,操作完我们可以直接从组件中获取最新的data进行json的替换 $0.__vue__--下次初始化就是最新的了

3 在线填写完的excel导出到本地生成excel文件--excelJS--exceljs文档

采用原因:功能巨强大,excel的功能基本都支持自定义,而且具有中文文档--以下已如何设置单元格信息作为举例

主要逻辑就是将excel数据先导出,基于数据进行自定义的转换

重点:导出的虚拟excel此时的单元格坐标 比数据单元格坐标少1(数据为数组,索引从0开始)--要一一对应

相关推荐
格子软件1 小时前
2026年GEO优化系统源码级状态机与多模型调度拆解
java·前端·vue.js·人工智能·vue·geo
HUMHSX2 小时前
Vue 项目启动全流程解析:从入口文件到全局指令注册与页面渲染
前端·javascript·vue.js
有颜有货2 小时前
PMC生产排产的4种算法,一次讲清
java·服务器·前端
小虎牙0072 小时前
Android kotlin图片库Coil源码详解
android·前端
随风一样自由2 小时前
【前端领域】前端开发核心应用场景与落地实践
前端·前端框架
an317422 小时前
弹窗数据流设计的两种高阶架构实践
前端·vue.js·架构
谢尔登3 小时前
【React】 状态管理方案
前端·react.js·前端框架
用户2136610035723 小时前
Vue商品详情与放大镜组件
前端·javascript
半个落月3 小时前
从Tapas小Demo理清localStorage、事件与this
前端·javascript
李明卫杭州3 小时前
Vue2 中 v-model 处理不同数据结构的技巧
前端·javascript·vue.js