没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2024-07-01 10:40:39.427|阅读 16 次
概述:本文主要介绍如何用DHTMLX Gantt将上下文菜单集成到JavaScript Gantt图中,欢迎下载最新版组件体验!
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
DHTMLX Gantt是用于跨浏览器和跨平台应用程序的功能齐全的Gantt图表。可满足项目管理应用程序的所有需求,是最完善的甘特图图表库。
DHTMLX Gantt是一个高度可定制的工具,可以与项目管理应用程序所需的其他功能相补充。在本文中您将学习如何使用自定义上下文菜单来补充基于DHTMLX的JavaScript甘特图,来提高用户在任务管理中的效率。考虑到DHTMLX产品的良好互兼容性,DHTMLX Suite的Menu小部件是实现本教程目标的甘特图组件的完美补充。
在上文中(点击这里回顾>>)我们为大家介绍了如何初始化和配置上下文菜单,本文继续介绍如何完成创建/更新/删除以及复制/粘贴操作,更多内容请持续关注我们哟~
首先,我们描述创建/更新/删除部分,本节包含以下嵌套菜单项:
这一项添加了一个同级别的任务,只在被点击的任务顶部:
case "add_sibling_above": gantt.createTask({ id: gantt.uid(), text: "New task", start_date: task.start_date, duration: 1 }, task.parent, gantt.getTaskIndex(task.id)); break;
为此,需要将任务的父节点指定为第二个参数,并将分支内任务的索引指定为第三个参数。
这个项目添加了一个相同级别的任务,只是在被点击的任务下面。
case "add_sibling_below": gantt.createTask({ id: gantt.uid(), text: "New task", start_date: task.start_date, duration: 1 }, task.parent, gantt.getTaskIndex(task.id) + 1); break;
为此需要将任务的父节点指定为第二个参数,并将分支内任务的索引增加1作为第三个参数。
这个项目在分支的顶部添加一个子任务(在所有其他子任务之上):
case "add_subtask_top": gantt.createTask({ id: gantt.uid(), text: "New subtask", start_date: task.start_date, duration: 1 }, task.id, 0); break;
为此将任务ID指定为第二个参数,并将零索引设置为第三个参数。
这个项目在分支的底部添加一个子任务(在所有其他子任务下面):
case "add_subtask_bottom": gantt.createTask({ id: gantt.uid(), text: "New subtask", start_date: task.start_date, duration: 1 }, task.id); break;
为此,应该将任务ID指定为第二个参数,并省略第三个参数。以同样的方式,使用甘特图网格区域中的内置“+”按钮添加任务。
此项目打开任务的lightbox(编辑表单)。
case "edit":
gantt.showLightbox(task.id);
break;
此项目将在删除任务时打开确认消息框。
case "delete": gantt.confirm({ text: "Delete task?", ok: "Yes", cancel: "No", callback: function (result) { if (result && gantt.isTaskExists(task.id)) { gantt.deleteTask(task.id); } } }); break;
如果用户对消息框中的问题是肯定的,则删除该任务。
使用上下文菜单的这一部分,最终用户可以对任务执行剪切、复制和粘贴操作。
在这里,任务被标记为剪切,以便稍后可以将其移动到其他位置。由于最终用户可能决定不复制任务,而是删除任务,因此有必要检查tasksToCopy数组中是否存在与任务相关的ID。如果带有任务的ID在数组中,则应该将其从数组中删除。
接下来,检查任务ID是否不在tasksToCut数组中,来排除重复的ID。如果具有该ID的任务不在数组中,则将其添加到数组中。之后,您可以使用样式刷新任务来突出显示它。
case "cut": const copyIndex = tasksToCopy.indexOf(task.id) > -1; if (copyIndex) { tasksToCopy.splice(copyIndex, 1) } // exclude duplicates if (tasksToCut.indexOf(task.id) === -1) { tasksToCut.push(task.id); } gantt.refreshTask(task.id); break;
在这里,任务被标记为复制,以便稍后可以将其添加到其他位置。由于最终用户可能决定不切剪切任务,而是复制任务,因此需要检查任务ID是否在tasksToCut数组中。如果是,则将其从数组中移除。接下来,检查taskToCopy数组中是否缺少任务ID,以排除重复的ID。如果任务ID不在数组中,则将其添加到数组中。之后,重新绘制任务来使用样式突出显示它。
case "copy": const cutIndex = tasksToCut.indexOf(task.id) > -1; if (cutIndex) { tasksToCut.splice(cutIndex, 1) } // exclude duplicates if (tasksToCopy.indexOf(task.id) === -1) { tasksToCopy.push(task.id); } gantt.refreshTask(task.id); break;
这里执行了pasteTasks函数,它复制并移动被标记的任务到调用上下文菜单的任务下面。
case "paste_sibling": pasteTasks(task.parent, gantt.getTaskIndex(task.id) + 1); break;
与前面的选项一样,这里执行了pasteTasks函数,它将在调用上下文菜单的任务中复制和移动标记的任务。
case "paste_child": pasteTasks(task.id); break;
在这里,复制和剪切标记从任务中删除。
case "cancel_paste": tasksToCopy = []; tasksToCut = []; gantt.render(); break;
篇幅有限未完待续,更多内容敬请期待.......
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn
文章转载自:慧都网FastReport .NET 的主要功能之一是能够将多份报告合并为一份。当您需要合并来自不同来源的数据或以更方便的格式呈现信息时,此功能非常有用。在本文中,我们将讨论如何在 FastReport .NET 中将多份报告合并为一份。
本文将手把手教你如何用VMProtect对这一关键函数进行虚拟化保护,大幅提升代码安全性,让逆向工程攻击者无从下手!
在 PDF 文档中添加页眉和页脚有助于保持一致的版式和专业的外观。本文将介绍如何使用 Spire.PDF for Java,通过 Java 在现有的 PDF 文档中添加页眉和页脚,并提供详细的步骤和代码示例。
对于开发人员来说,由于自动化和定制化,通常首选使用编程方法来去除 PDF 中的水印。Aspose.PDF 提供可靠且可定制的解决方案,可无缝集成到各种应用程序中,确保准确性并保持文档完整性。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@wqylolg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢