Javascript 从数组动态构建json以在d3中使用
我正在尝试构建一个平面Json(不确定称之为Json对象或Json字符串),以构建一个树Json层次结构模型Javascript 从数组动态构建json以在d3中使用,javascript,json,d3.js,Javascript,Json,D3.js,我正在尝试构建一个平面Json(不确定称之为Json对象或Json字符串),以构建一个树Json层次结构模型 var data = new Array(); data.push({"name":Rows[f][0],"parent":Rows[f][1]}); //here f is the index to the array 当我将上面的“数据”(平面json)提供给下面的代码来构建树json时,它什么也不构建——treeData.length为零 var da
var data = new Array();
data.push({"name":Rows[f][0],"parent":Rows[f][1]}); //here f is the index to the array
当我将上面的“数据”(平面json)提供给下面的代码来构建树json时,它什么也不构建——treeData.length为零
var dataMap = data.reduce(function(map, node) {
map[node.name] = node;
return map;
}, {});
var treeData = [];
data.forEach(function(node) {
var parent = dataMap[node.parent];
if (parent) {
(parent.children || (parent.children = []))
.push(node);
} else {
treeData.push(node);
}
});
alert(treeData.length); //Returns 0.
当输入到treeData json生成器时,即使下面的代码也会给出相同的结果
var data = new Array();
for (var f=0; f<Rows.length; f++ ) {
var tmp1={};
tmp1[name] = Rows[f][0];
tmp1[parent] = Rows[f][1];
data.push(tmp1);
}
请帮助正确构建平面json 您的代码似乎对我很有用:(在for循环方法中,您应该编写
tmp1[“name”]
和tmp1[“parent”]
)这终于奏效了。向数组元素添加.text。无论如何,感谢@tewathia。
data.push({"name":"Apple","parent":"fruit"});