提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
转帖|行业资讯|编辑:胡涛|2023-02-03 11:13:38.780|阅读 353 次
概述:本文介绍项目管理工具DHTMLX Gantt 闭坑指南,欢迎查阅
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
DHTMLX Gantt是用于跨浏览器和跨平台应用程序的功能齐全的Gantt图表。可满足项目管理应用程序的大部分开发需求,具备完善的甘特图图表库,功能强大,价格便宜,提供丰富而灵活的JavaScript API接口,与各种服务器端技术(PHP,ASP.NET,Java等)简单集成,满足多种定制开发需求。
公司业务需要,管理层做项目管理就会制定项目计划,为了更好的的做好项目计划就需要用到做计划常用的工具甘特图,而且做好计划管理对项目的风险管控也有很大的好处。
1.引入
1.引入js
import {gantt , Gantt} from "yys-pro-gantt";2.导入css
import "yys-pro-gantt/codebase/dhtmlxgantt.css"; import "yys-pro-gantt/codebase/skins/dhtmlxgantt_terrace.css";b、style中导入方式
@import "~yys-pro-gantt/codebase/dhtmlxgantt.css"; /*@import "~yys-pro-gantt/codebase/skins/dhtmlxgantt_terrace.css"; // 皮肤*/ @import "./skins/dhtmlxgantt_yys.css"; // 自定义皮肤 不需要下面可以不引入 // import "dhtmlx-gantt/codebase/locale/locale_cn" ; // 本地化 // import "dhtmlx-gantt/codebase/ext/dhtmlxgantt_tooltip.js"; // 任务条悬浮提示 // this.createScript("//export.dhtmlx.com/gantt/api.js"); // 使用甘特图自带的导出功能必须引入 createScript createScript(url: string) { const scriptElement = document.createElement("script"); scriptElement.src = url; const headerElement = document.querySelector("head") as any; if (headerElement) { headerElement.appendChild(scriptElement); } }
2、甘特图初始化
template <div ref="gantt" id="yys-gantt"> </div> vuejs gantt() { // 获取到dom元素 return this.$refs.gantt as any; } get ganttInstance() { // 获取到甘特图实例便能调用甘特图的所有方法 return gantt || Gantt.getGanttInstance(); } this.ganttInstance.init(this.gantt()); this.ganttInstance.clearAll(); this.ganttInstance.parse(this.tasks);
3、甘特图更新
a. tasks变更甘特图更新
@Watch("config", { immediate: true, deep: true }) updateConfig(nConfig: any, oConfig: any) { if (JSON.stringify(nConfig) === JSON.stringify(oConfig)) { return; } this.$nextTick(() => { if (this.config) { Object.assign(this.ganttInstance.config, this.defaultConfig, this.config); } if (this.gantt()) { this.ganttInstance.init(this.gantt()); gantt.clearAll(); this.ganttInstance.parse(this.tasks); } }) }
b. config变更甘特图更新
@Watch("config", { deep: true }) updateConfig() { if (this.config) { Object.assign(this.ganttInstance.config, this.defaultConfig, this.config); } if (this.gantt()) { this.ganttInstance.init(this.gantt()); gantt.clearAll(); this.ganttInstance.parse(this.tasks); } }
4、甘特图销毁
gantt.destructor()
1、data里面的部分属性的key是不能更改的,比如id,parent,start_date、end_date、progress、open
links里面的全部属性的key是不能更改的id source target type
2、data如果type是project,那么这条数据的开始时间会取其里面所有数据的最早开始时间,结束时间会取里面所有数据的最晚开始时间,如果这条数据里面的所有数据都是空数据,那么start_date会甘特图渲染的最早时间,end_date是start_date的后一天,这样数据就会不准确?
解决方案: data里加个unscheduled属性来控制是否渲染这条数据,需要注意的是在所有涉及到日期的地方都要加,如tooltips_text 、columns、 拖拽等等
3、 dhtmlx-gantt都是下划线分割,而且api中都是这样,但在layout中min_width、max_width不生效,要用minWidth、maxWidth替换才生效。
4、排序后的数据默认从页面获取的row元素可能是不准确的,需要从dataStroe中获取。
5、在左侧表格和列都能拖拽的情况下,会突然弹回到默认宽度?
解决方案:监控config阻止掉更新;
@Watch("config", { deep: true }) updateConfig(nConfig: any, oConfig: any) { if (JSON.stringify(nConfig) === JSON.stringify(oConfig)) return; }
6、默认情况下甘特图经常出现错误提示?
解决方案:将show_errors设为false
7、link添加类型&&计划和里程碑规则
link_class: (link: any) => { // console.log(link) const {type} = link; return `link-type-${type}`; }, target.forEach((linkId: any) => { const link = this.gantt.getLink(linkId); const { sourceTask, targetTask, type, } = this.getSourceTaskAndTargetTaskByLink(link); switch (type) { case LinkType.fs: if ( +targetTask.start_date < +sourceTask.end_date ) { fsLimit(task, sourceTask); } break; case LinkType.ss: if (+targetTask.start_date > +sourceTask.start_date) { limitLeft(task, targetTask); } break; case LinkType.ff: if (+targetTask.end_date > +sourceTask.end_date) { limitRight(task, targetTask); } break; case LinkType.sf: if (+targetTask.start_date > +sourceTask.end_date) { limitRight(task, targetTask); } break; default: break; } fsMoveLimit(task: any, limit: any) { const dur = task.end_date - task.start_date; if (task.type === GANTT_TYPE.计划 && limit.type === GANTT_TYPE.计划) { task.start_date = new Date(limit.end_date); task.end_date = new Date(limit.start_date + dur); } if (task.type === GANTT_TYPE.计划 && limit.type === GANTT_TYPE.里程碑) { task.start_date = new Date(limit.end_date); task.end_date = new Date(limit.start_date + dur); } if (task.type === GANTT_TYPE.里程碑 && limit.type === GANTT_TYPE.里程碑) { task.start_date = new Date(limit.start_date); } if (task.type === GANTT_TYPE.里程碑 && limit.type === GANTT_TYPE.计划) { task.start_date = new Date(limit.end_date); } } fsResizeLimit(task: any, limit: any) { const dur = task.end_date - task.start_date; if (task.type === GANTT_TYPE.计划 && limit.type === GANTT_TYPE.计划) { task.start_date = new Date(limit.end_date); } if (task.type === GANTT_TYPE.计划 && limit.type === GANTT_TYPE.里程碑) { task.start_date = new Date(limit.end_date); } } .gantt_task_link.link-type-0 .gantt_line_wrapper:nth-of-type(2)::before{ content: "fs"; position: absolute; top: 10px; left: 15px; font-size: 16px; } .gantt_task_link.link-type-1 .gantt_line_wrapper:nth-of-type(2)::before{ content: "ss"; position: absolute; top: 10px; left: 15px; font-size: 16px; } .gantt_task_link.link-type-2 .gantt_line_wrapper:nth-of-type(2)::before{ content: "ff"; position: absolute; top: 10px; left: 15px; font-size: 16px; } .gantt_task_link.link-type-3 .gantt_line_wrapper:nth-of-type(2)::before{ content: "sf"; position: absolute; top: 10px; left: 15px; font-size: 16px; }
本文转自://juejin.cn/post/6930900493602390024 ,如有侵权,请联系删除
DHTMLX Gantt享有超十年声誉,支持跨浏览器和跨平台,性价比高,可满足项目管理控件应用的所有需求,是最完善的甘特图图表库。
甘特图控件交流群:764148812
欢迎进群交流讨论,获取更多帮助请联系
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn
2024年对于FastReport来说是充满挑战和收获的一年。FastReport在多个领域取得了重要突破和创新成果,不仅不断优化现有产品,
通过提供强大的3D CAD数据访问工具并适用于桌面、移动和Web的高级环境3D可视化发动机,HOOPS在提升造船设计和制造流程的效率方面发挥了重要作用。
HOOPS Luminate在汽车行业中的应用具有广泛的潜力和深远的影响。它通过提供高效的3D可视化、虚拟装配与拆解、性能分析、客户定制等功能,帮助汽车制造商在设计、生产和销售过程中提升效率、降低成本并提高产品质量。
在不断发展的软件开发世界中,使工具和框架与最新的平台版本保持同步至关重要,欢迎查阅~
一个用于构建跨浏览器Web应用和移动应用的强大JavaScript UI库。
DHTMLX Scheduler一个类似于Google日历的强大JavaScript日程安排控件。
DHTMLX Gantt针对您的解决方案的交互式JavaScript / HTML5甘特图
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@pclwef.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢