Vue3+el-table实现甘特图

Vue3 + el-table实现甘特图效果

代码gitee

整体实现效果如下

进度列,可以通过设置天或小时,切换不同列显示类型。

涉及到的问题
1、通过Worker解决js线程堵塞问题

在根据时间动态生成列时,由于开始时间与结束时间跨度过大时,计算列逻辑,会堵塞js线程,甚至卡死浏览器。通过Worker单独启一个副线程,单独计算列。

在public文件夹下,新增一个columnWorker.js文件

具体实现逻辑:通过不断循环累加开始时间,与结束时间进行比较,生成所需要展示的列。具体代码实现可参考gitee仓库代码。

2、整合接口返回数据,动态适配列

这里也是根据开始时间和结束时间,但是会判断过滤掉时间中没有时分秒的数据。数据处理时机是在方法handleColumn中的回调函数中调用。在Worker方法中会返回当前列所涉及到的列数据,并在handleData方法中进行数据开始时间,结束时间跨度与列时间跨度是否有交集,如果有,则在该条数据中新增字段,该字段就是生成列的数据中key属性值。

剩下的可以clone代码自己看一看,代码逻辑很简单,就没有写备注。如果有问题可以提一提。

相关推荐
一只小阿乐21 小时前
react 封装弹框组件 传递数据
前端·javascript·react.js
533_21 小时前
[element-plus] el-tree 动态增加节点,删除节点
前端·javascript·vue.js
禁止摆烂_才浅21 小时前
前端开发小技巧-【JavaScript】- 获取元素距离 document 顶部的距离
前端·javascript·react.js
wshzd21 小时前
LLM之Agent(二十九)|LangChain 1.0核心组件介绍
前端·javascript·langchain
程序猿_极客21 小时前
Vue 2脚手架从入门到实战核心知识点全解析(day6):从工程结构到高级通信(附代码讲解)
前端·javascript·vue.js·vue2学习笔记
一只小阿乐21 小时前
vue3 使用v-model开发弹窗组件
javascript·vue.js·elementui
web加加21 小时前
vue3 +vite项目页面防f12,防打开控制台
前端·javascript·vue.js
遥遥晚风点点1 天前
Spark导出数据文件到HDFS
前端·javascript·ajax
克里斯蒂亚诺更新1 天前
微信小程序 点击某个marker改变其大小
开发语言·前端·javascript
KYumii1 天前
智慧判官-分布式编程评测平台
vue.js·spring boot·分布式·spring cloud·java-rabbitmq