Vue3+el-table实现甘特图

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

代码gitee

整体实现效果如下

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

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

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

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

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

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

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

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

相关推荐
小胖霞20 小时前
企业级全栈项目(14) winston记录所有日志
vue.js·前端框架·node.js
栀秋66620 小时前
“无重复字符的最长子串”:从O(n²)哈希优化到滑动窗口封神,再到DP降维打击!
前端·javascript·算法
xhxxx20 小时前
不用 Set,只用两个布尔值:如何用标志位将矩阵置零的空间复杂度压到 O(1)
javascript·算法·面试
有意义20 小时前
斐波那契数列:从递归到优化的完整指南
javascript·算法·面试
OpenTiny社区21 小时前
TinyEngine2.9版本发布:更智能,更灵活,更开放!
前端·vue.js·低代码
Mr.Jessy21 小时前
JavaScript高级:深入对象与内置构造函数
开发语言·前端·javascript·ecmascript
温宇飞21 小时前
深入理解 JavaScript 模块系统:CJS 与 ESM 的实现原理
javascript
老华带你飞21 小时前
列车售票|基于springboot 列车售票系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习·spring
幸运小圣21 小时前
深入理解ref、reactive【Vue3工程级指南】
前端·javascript·vue.js
用户479492835691521 小时前
面试官最爱挖的坑:用户 Token 到底该存哪?
前端·javascript·面试