Vue3+el-table实现甘特图

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

代码gitee

整体实现效果如下

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

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

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

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

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

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

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

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

相关推荐
山河木马11 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林81812 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
kyriewen14 小时前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
SmartBoyW15 小时前
深入ECMAScript规范:彻底搞懂JS隐式类型转换与底层ToPrimitive机制
前端·javascript
咪库咪库咪16 小时前
vue3-组件
vue.js
用户8524950718416 小时前
解密 JavaScript 中的 this:谁才是真正的调用者?
javascript·面试
10share16 小时前
100行代码 模拟实现Vue 响应式系统
前端·vue.js
Heo16 小时前
Vite进阶用法详解
前端·javascript·面试
铁皮饭盒17 小时前
Next.js 风格路由内置?Bun FileSystemRouter 凭啥这么香
javascript
小林ixn18 小时前
别再背八股了!从 5 个真实场景彻底搞懂 JavaScript 的 this
javascript