在管理项目时,用户可能需要更改任务顺序或在多个甘特项目之间移动任务。今天,我们将熟悉在dhtmlxGantt中实现此功能的方式。
dhtmlxGantt是用于跨浏览器和跨平台应用程序的功能齐全的JavaScript / HTML5甘特图,允许你创建动态甘特图,并以一个方便的图形化方式可视化项目进度。有了dhtmlxGantt,你可以显示活动之间的依赖关系,显示具有完成百分比阴影的当前任务状态以及组织活动到树结构。
dhtmlxGantt正式版
在管理项目时,用户可能需要更改任务顺序或在多个甘特项目之间移动任务。今天,我们将熟悉在dhtmlxGantt中实现此功能的方式。
我们的HTML5 Gantt提供了两种在 格中对任务进行重新排序的替代方法:
- 通过拖放
- 通过分类
默认情况下,两种模式均禁用。
为了通过拖放操作使任务重新排序,我们需要将order_branch选项设置为’true’:
// ordering tasks only inside a branchgantt.config.order_branch = true;gantt.init("gantt_here");
order_branch属性激活“分支”模式,该模式可对同一嵌套级别内的任务的重新排序。
更改任务位置涉及触发onBeforeTaskMove或onAfterTaskMove事件。第一个可以用来控制任务可以移到哪里。为了防止移动到另一个子分支,请使用onBeforeTaskMove事件:
gantt.config.order_branch = true;gantt.attachEvent("onBeforeTaskMove", function(id, parent, tindex){ var task = gantt.getTask(id); if(task.parent != parent) return false; return true;});gantt.init("gantt_here");
如果甘特图中包含很多任务,则分支重新排序的默认模式可能会降低性能。为了加快速度,您可以使用“标记”模式:
gantt.config.order_branch = "marker";
在此模式下,仅将任务名称重新排序(按住鼠标左键),并且仅当任务放在目标位置时(松开键)才重新渲染甘特图:
与默认模式不同,更改任务位置不涉及触发onBeforeTaskMove或onAfterTaskMove事件。为防止任务掉到特定位置,我们可以改用onBeforeRowDragMove事件。请注意,它仅在“标记”模式下有效:
// ordering tasks only inside a branchgantt.config.order_branch = "marker";gantt.attachEvent("onBeforeRowDragMove", function(id, parent, tindex){ var task = gantt.getTask(id); if(task.parent != parent) return false; return true;});gantt.init("gantt_here");
希望我们的教程对您有所帮助!如果您想亲自试用dhtmlxGantt,请下载30天免费评估版。
dhtmlxGantt可以集成到APS系统中,助力生产排程工作!还可以进行资源调度系统定制,帮助企业完善资源管理,简化资源计划,实现利润增加!
想要购买dhtmlxGantt正版授权,或了解更多产品信息请点击【咨询在线客服】
标签:
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!