我正在用
- 父任务可以取决于另一个父母或子任务,
- 子任务可以取决于另一个孩子或父级任务
- 可以具有多个依赖性任务,
- 只有一旦完成任务完成
如果将依赖关系添加到父a下的任务中,则将偏移移动到父c中的所有任务,例如so
这是我的数据的结构如何
const tasks = [
{ id: 'parent-a', text: 'Parent A', duration: null },
{ id: 'child-a-1', text: 'Child 1', parent: 'Parent A', duration: 5 },
{ id: 'child-a-2', text: 'Child 2', parent: 'Parent A', duration: 5 },
// ...
]
const dependencies = [
{ id: 1, source: 'child-a-1', target: 'child-a-2' },
{ id: 1, source: 'parent-b', target: 'parent-c' },
// ...
]
计算开始的开始每个任务的日期,遍历每个任务,并根据任务的持续时间动态设置日期。
let startDate = new Date()
tasks.forEach((task, i, array) => {
const correspondingDependency = dependencies.find(d => d.id === task.id)
if (correspondingDependency) {
array[i].start_date = new Date(startDate.setDate(startDate.getDate() + duration))
}
})
此方法的问题是,如果找到了依赖关系,则不会更新任何 start_date
在依赖项的末尾
数组(即Child-C-1取决于Child-A-3),
我觉得我可能需要在这里使用递归,但不确定。希望这一切都有意义 - 任何帮助都将受到赞赏
I'm building a Gantt Chart with dhtmlx-gantt that contains parent and child tasks.
- A parent task can be a dependent on another parent or child task
- A child task can be dependent on another child or parent task
- Tasks can have multiple dependencies
- A dependent task can only begin once it's ruling task is complete
data:image/s3,"s3://crabby-images/2b407/2b407be9f5b2a9e46ca4d24800a72717bcfed725" alt="enter image description here"
If a dependency is added to a task under Parent A to Parent C, this will move the shift the start date to all tasks in Parent C, like so
data:image/s3,"s3://crabby-images/0f9a8/0f9a8dc815a0ff68d6f5bec36bb319f9f5c633c6" alt="enter image description here"
Here's how my data is structured
const tasks = [
{ id: 'parent-a', text: 'Parent A', duration: null },
{ id: 'child-a-1', text: 'Child 1', parent: 'Parent A', duration: 5 },
{ id: 'child-a-2', text: 'Child 2', parent: 'Parent A', duration: 5 },
// ...
]
const dependencies = [
{ id: 1, source: 'child-a-1', target: 'child-a-2' },
{ id: 1, source: 'parent-b', target: 'parent-c' },
// ...
]
To calculate the start date for each task, loop through each task and set the date dynamically based on the duration of the task
let startDate = new Date()
tasks.forEach((task, i, array) => {
const correspondingDependency = dependencies.find(d => d.id === task.id)
if (correspondingDependency) {
array[i].start_date = new Date(startDate.setDate(startDate.getDate() + duration))
}
})
The problem with this method is it won't update any start_date
s for prior tasks if a dependency is found at the end of the dependencies
array (i.e., child-c-1 is dependent on child-a-3)
I feel like I may need to use recursion here, but not quite sure. Hope this all makes sense - any help is appreciated
发布评论
评论(1)
据我了解,您正在开发一种自动计划逻辑,类似于在DHTMLX gantt的付费版本中可以使用。
Fui,我在销售该产品的DHTMLX工作,所以我无法深入研究如何开发免费的替代方案:)
但是我想我可以给您一些一般的考虑。
https://en.wikipedia.org/wiki/wiki/directed_graph_graph
任务是顶点的地方,链接是图形的边缘。
一旦能够以图的形式表示数据,其他所有内容都非常简单:
具有挑战性的部分是将您的数据结构从Gantt的亲子层次结构转换为有向图的平坦结构。基本上,这意味着您想摆脱数据集中的项目,并转换涉及与其子任务之间关系的项目。
一开始听起来可能很复杂,但是代码将易于理解且易于调试。
如果您限制了所做的工作范围,例如不允许项目之间的关系,则可能会采用更简单,更直观的方法逃脱。但是对于通用解决方案,我认为我概述的方法是最安全的选择。
PS
如果您要实施与DHTMLXGANTT类似的自动调度(
https://docs.dhtmlx.com/gantt/desktop__auto_scheduling.html ) and if您计划在商业上使用它,可能值得获得付费版本的DHTMLXGANTT,其中可以在其中开箱即用。
实施可靠的自动安排算法可能需要大量时间和精力,因此,获得现成的解决方案可能比从头开始开发它便宜。
As I understand, you're developing an auto planning logic, similar to the Auto Scheduling that is available in paid versions of dhtmlx Gantt.
FUI, I work for DHTMLX, which sells this product, so I can't go deeply into how to develop a free alternative:)
But I think I can give you some general considerations.
https://en.wikipedia.org/wiki/Directed_graph
Where Tasks are vertices, and Links are the edges of the Graph.
Once you are able to represent your data in the form of a graph, everything else is really simple:
The challenging part is to convert your data structure from the parent-child hierarchy of Gantt to the flat structure of Directed Graph. Basically, it means you want to get rid of projects in your dataset and convert relations that involve projects with relations between their subtasks.
It may sound complicated at the start, but the code will be easy to understand and easy to debug.
If you limit the scope of what you're doing, e.g. disallow relations between projects, you may get away with a simpler and more intuitive approach. But for a general-purpose solution, I think the approach I've outlined is the safest bet.
P.S.
If you're implementing auto scheduling similar to that in dhtmlxGantt (
https://docs.dhtmlx.com/gantt/desktop__auto_scheduling.html ) and if you plan to use it commercially, it might be worthwhile to get a paid version of dhtmlxGantt where auto-scheduling is available out of the box.
Implementing a reliable auto-scheduling algorithm may take a lot of time and effort, so getting a ready solution may be less expensive than developing it from scratch.