「实战应用」如何用DHTMLX将上下文菜单集成到JavaScript甘特图中(二)

news/2024/10/5 10:55:19/

DHTMLX Gantt是用于跨浏览器和跨平台应用程序的功能齐全的Gantt图表。可满足项目管理应用程序的所有需求,是最完善的甘特图图表库。

DHTMLX Gantt是一个高度可定制的工具,可以与项目管理应用程序所需的其他功能相补充。在本文中您将学习如何使用自定义上下文菜单来补充基于DHTMLX的JavaScript甘特图,来提高用户在任务管理中的效率。考虑到DHTMLX产品的良好互兼容性,DHTMLX Suite的Menu小部件是实现本教程目标的甘特图组件的完美补充。

DHTMLX Gantt最新正式版下载

在上文中(点击这里回顾>>)我们为大家介绍了如何初始化和配置上下文菜单,本文继续介绍如何完成创建/更新/删除以及复制/粘贴操作,更多内容请持续关注我们哟~

创建/更新/删除

「实战应用」如何用<a class=DHTMLX将上下文菜单集成到JavaScript甘特图中" height="314" src="https://img-blog.csdnimg.cn/img_convert/d3cad34bd9d312ceb46c9ba5a7580f94.png" width="1024" />

首先,我们描述创建/更新/删除部分,本节包含以下嵌套菜单项:

  • 在上面添加sibling

这一项添加了一个同级别的任务,只在被点击的任务顶部:

javascript>javascript">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;

为此,需要将任务的父节点指定为第二个参数,并将分支内任务的索引指定为第三个参数。

  • 在下面添加sibling

这个项目添加了一个相同级别的任务,只是在被点击的任务下面。

javascript>javascript">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作为第三个参数。

  • 在顶部添加子任务

这个项目在分支的顶部添加一个子任务(在所有其他子任务之上):

javascript>javascript">case "add_subtask_top":
gantt.createTask({ id: gantt.uid(), text: "New subtask", start_date: task.start_date, duration: 1 }, task.id, 0);
break;

为此将任务ID指定为第二个参数,并将零索引设置为第三个参数。

  • 在底部添加子任务

这个项目在分支的底部添加一个子任务(在所有其他子任务下面):

javascript>javascript">case "add_subtask_bottom":
gantt.createTask({ id: gantt.uid(), text: "New subtask", start_date: task.start_date, duration: 1 }, task.id);
break;

为此,应该将任务ID指定为第二个参数,并省略第三个参数。以同样的方式,使用甘特图网格区域中的内置“+”按钮添加任务。

  • 编辑任务

此项目打开任务的lightbox(编辑表单)。

javascript>javascript">case "edit":
gantt.showLightbox(task.id);
break;
  • 删除任务

此项目将在删除任务时打开确认消息框。

javascript>javascript">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;

如果用户对消息框中的问题是肯定的,则删除该任务。

复制/粘贴

「实战应用」如何用<a class=DHTMLX将上下文菜单集成到JavaScript甘特图中" height="317" src="https://img-blog.csdnimg.cn/img_convert/1a7a58db85d72dd511a32800b838ddf7.png" width="1024" />

使用上下文菜单的这一部分,最终用户可以对任务执行剪切、复制和粘贴操作。

  • 剪切

在这里,任务被标记为剪切,以便稍后可以将其移动到其他位置。由于最终用户可能决定不复制任务,而是删除任务,因此有必要检查tasksToCopy数组中是否存在与任务相关的ID。如果带有任务的ID在数组中,则应该将其从数组中删除。

接下来,检查任务ID是否不在tasksToCut数组中,来排除重复的ID。如果具有该ID的任务不在数组中,则将其添加到数组中。之后,您可以使用样式刷新任务来突出显示它。

javascript>javascript">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不在数组中,则将其添加到数组中。之后,重新绘制任务来使用样式突出显示它。

javascript>javascript">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;
  • 粘贴sibling

这里执行了pasteTasks函数,它复制并移动被标记的任务到调用上下文菜单的任务下面。

javascript>javascript">case "paste_sibling":
pasteTasks(task.parent, gantt.getTaskIndex(task.id) + 1);
break;
  • 粘贴child

与前面的选项一样,这里执行了pasteTasks函数,它将在调用上下文菜单的任务中复制和移动标记的任务。

javascript>javascript">case "paste_child":
pasteTasks(task.id);
break;
  • 取消复制/剪切操作

在这里,复制和剪切标记从任务中删除。

javascript>javascript">case "cancel_paste":
tasksToCopy = [];
tasksToCut = [];
gantt.render();
break;

篇幅有限未完待续,更多内容敬请期待.......


http://www.ppmy.cn/news/1473447.html

相关文章

FlutterUnit TolyUI | 布局游乐场

theme: cyanosis FlutterUnit 基于 TolyUI 大大简化了界面构建的代码复杂程度&#xff0c;因此之前想要实现的一些小功能&#xff0c;就可以轻松支持。布局游乐场是通过交互的方式来 直观体验 组件的布局特性&#xff0c;从而更易学和掌握。目前 FlutterUnit 已在 知识集录模块…

收银系统源码-营销活动-积分商城

1. 功能描述 营运抽奖&#xff1a;智慧新零售收银系统&#xff0c;线上商城的营销插件&#xff0c;由商户运营&#xff0c;用户通过多种渠道可以获取积分&#xff0c;不仅支持在收银端抵用&#xff0c;还可以在积分商城内兑换优惠券或者真实商品&#xff0c;提升会员活跃度&am…

Spring Boot + liteflow 居然这么好用!实战

在我们的日常开发中&#xff0c;经常会遇到一些需要串行或并行处理的复杂业务流程。 那我们该如何利用Spring Boot结合liteflow规则引擎来简化我们的业务流程 先看一个实战案例&#xff01;&#xff01; 在电商场景下&#xff0c;当订单完成后&#xff0c;我们需要同时进行积…

Ubuntu、CentOs更换源(阿里云的源)

ubuntu 备份当前的apt配置文件 sudo mv /etc/apt/sources.list /etc/apt/sources.list.backup编辑配置文件&#xff0c;将以下内容写到文件中sudo vi /etc/apt/sources.list deb https://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse deb-src ht…

SQL窗口函数详解

详细说明在sql中窗口函数是什么&#xff0c;为什么需要窗口函数&#xff0c;有普通的聚合函数了那窗口函数的意义在哪&#xff0c;窗口函数的执行逻辑是什么&#xff0c;over中的字句是如何使用和理解的&#xff08;是不是句句戳到你的痛点&#xff0c;哼哼&#xff5e;&#x…

一文了解常见DNS问题

当企业的DNS出现故障时&#xff0c;为不影响企业的正常运行&#xff0c;团队需要能够快速确定问题的性质和范围。那么有哪些常见的DNS问题呢&#xff1f; 域名解析失败&#xff1a; 当您输入一个域名&#xff0c;但无法获取到与之对应的IP地址&#xff0c;导致无法访问相应的网…

支持离线的稍后阅读工具HamsterBase

什么是 HamsterBase &#xff1f; HamsterBase 是一个以隐私优先的、离线友好的稍后阅读工具。软件本身不需要连接互联网&#xff0c;没有遥测功能&#xff0c;不收集任何私人信息&#xff0c;也不需要登录或注册。同时&#xff0c;HamsterBase 是一个开放的知识管理工具&#…

【Python】基于KMeans的航空公司客户数据聚类分析

&#x1f490;大家好&#xff01;我是码银~&#xff0c;欢迎关注&#x1f490;&#xff1a; CSDN&#xff1a;码银 公众号&#xff1a;码银学编程 实验目的和要求 会用Python创建Kmeans聚类分析模型使用KMeans模型对航空公司客户价值进行聚类分析会对聚类结果进行分析评价 实…