javascript - Go.JS 图添加 Javascript 数组对象未按预期工作无哈希 ID
问题描述
这一定是格式问题,但我的图表不接受来自真实来源的新数据......我注意到 Go.js 没有生成哈希 ID
function updateGraph(node_list,myDiagram){
var model = $(go.TreeModel);
//add some dummy data
model.nodeDataArray =
[
{ key: 1, parent: 1, color: "lightblue"},
{ key: 2, parent: 1 , color: "lightblue"},
{ key: 3, parent: 2, color: "lightblue"}
];
//add real data
for(let id = 1; id < node_list.length; id++){
model.nodeDataArray.push({key: node_list[id].getNodeID(), parent: node_list[id].getNodeID(), color: "lightblue"});
}
console.log(model.nodeDataArray);
myDiagram.model = model;
}
安慰:
0: {key: 1, parent: 1, color: "lightblue", __gohashid: 409}
1: {key: 2, parent: 1, color: "lightblue", __gohashid: 410}
2: {key: 3, parent: 2, color: "lightblue", __gohashid: 411}
3: {key: "step_02_set_incoming_file_permissions", parent: "step_02_set_incoming_file_permissions", color: "lightblue"}
4: {key: "step_025_truncate", parent: "step_025_truncate", color: "lightblue"}
5: {key: "step_03_extract_item_sold_details", parent: "step_03_extract_item_sold_details", color: "lightblue"}
但是,如果我将虚拟数据设置为控制台打印出的硬编码值:
model.nodeDataArray =
[
{key: "step_02_set_incoming_file_permissions", parent: "step_01_starting_email", color: "lightblue"},
{key: "step_025_truncate", parent: "step_02_set_incoming_file_permissions", color: "lightblue"},
{key: "step_03_extract_item_sold_details", parent: "step_025_truncate", color: "lightblue"}
];
我得到一个带有哈希 id 的输出:
解决方案
好的,所以 Go.JS 需要另一个函数来正确添加数据。出于某种原因,您不能只喂它动态对象...addNodeData
根据Go.JS 文档调用该方法修复了图形问题!
model.addNodeData({key: node_list[id].getNodeID(), parent: node_list[id].getNodeID(), color: "lightblue"});
model.addLinkData( { from: node_list[id].getNodeID(), to: node_list[id].getNextNode() } ); //link data
推荐阅读
- amazon-web-services - 查找最新的 AWS API 版本以锁定版本
- c - #包括
导致错误 - javascript - 使用循环构建对象数组
- unity3d - 有什么方法可以改变 Unity 中自定义 Sprite 的 FilterMode?
- typescript - 可以选择在打字稿中扩展一种类型的道具?
- javascript - 根据另一个数组获取一个数组中元素的索引
- r - Rstudio没有读入文件
- python - 在 matplotlib 中创建非对称轴
- android - Android Studio 序列化
- google-analytics - 是否有一种解决方法可以在 Google Analytics(分析)中为同一目标创建多个渠道?