json数据的Javascript数据结构

时间:2016-01-14 00:16:23

标签: javascript json d3.js jenkins

嗨,我有一些来自Jenkins的JSON数据。我获取JSON并获取看起来像这样的作业对象:

{
     color: "#FF4136"
     name: "XXX-tomcat-accept"
     url: "http://1.1.7.9:8080/job/xxx-tomcat-verify/"
}

对于每个作业流,有三个作业

  • -verify
  • -accept
  • - 交货

我要做的是构建一个数组结构,它是一个数组数组或一个数组哈希,其中第一个元素是验证然后接受然后传递(与上面列表相同的顺序)。

这样的事情

0[xxx-tomcat-verify,xxx-tomcat-accept,xxx-tomcat-delivery]
1[xxx-linux-verify,xxx-linux-accept,xxx-linux-delivery]
2
3
......

我无法绕过逻辑重新组合上述结构中的数据。我想要做的是使用d3为Jenkins构建一个轻量级构建仪表板。以下代码构建作业并标记它们。只需要按照正确的顺序获取它们。

我的代码就是

d3.json("data.json", function(error, data) {

    job.forEach(function(d){

        //green balls !
        if (d.color === "blue") {
            d.color = "#2ECC40";
        }   else if(d.color === "notbuilt"){
            d.color = "#AAAAAA";

        } else if(d.color === "aborted"){
            d.color = "#0074D9";
        } else if(d.color === "red"){
            d.color = "#FF4136"

        }


        var svgContainer = d3.select("body").append("svg")
                            .attr("width", 460)
                            .attr("height", 110);

        var rectangle = svgContainer.append("rect")
                            .attr("x", 5)
                            .attr("y", 5)
                            .attr("width", 450)
                            .attr("height", 100)
                            .attr("text", d.name)
                            .attr("rx", 10)
                            .attr("ry", 10)
                            .attr("xlink:href", d.url)
                            .attr("fill", d.color);

        var text = svgContainer.selectAll("text")
                        .data(rectangle)
                        .enter()
                        .append("text");

        var textLabels = text
                 .attr("x", 20)
                 .attr("y", 60)
                 .text(d.name)
                 .attr("font-family", "Avro")
                 .attr("font-size", "30px")
                 .attr("fill", "#2f2f2f");



        });

});

1 个答案:

答案 0 :(得分:1)

您可以使用d3.nest()。

https://jsfiddle.net/ermineia/jz293y70/1/

var jobs = [{
     color: "#FF4136",
     name: "XXX-tomcat-verify",
     url: "http://1.1.7.9:8080/job/xxx-tomcat-verify/"
},
{
     color: "#FF4136",
     name: "XXX-tomcat-accept",
     url: "http://1.1.7.9:8080/job/xxx-tomcat-accept/"
},
{
     color: "#FF4136",
     name: "XXX-tomcat-delivery",
     url: "http://1.1.7.9:8080/job/xxx-tomcat-delivery/"
},
{
     color: "#FF4136",
     name: "XXX-linux-verify",
     url: "http://1.1.7.9:8080/job/xxx-tomcat-verify/"
},
{
     color: "#FF4136",
     name: "XXX-linux-accept",
     url: "http://1.1.7.9:8080/job/xxx-tomcat-accept/"
},
{
     color: "#FF4136",
     name: "XXX-linux-delivery",
     url: "http://1.1.7.9:8080/job/xxx-tomcat-delivery/"
}];

console.log( jobs );
var formatted_map = d3.nest().key( function( d ) { return d.name.substr( 0, d.name.lastIndexOf( '-' ) ); } ).map( jobs );
console.log( formatted_map );
console.log( JSON.stringify( formatted_map ))
var formatted_array = d3.nest().key( function( d ) { return d.name.substr( 0, d.name.lastIndexOf( '-' ) ); } ).entries( jobs );
console.log( formatted_array );
console.log( JSON.stringify( formatted_array ))

写出:

[Object, Object, Object, Object, Object, Object]
(index):78 Object {XXX-tomcat: Array[3], XXX-linux: Array[3]}
(index):79 {"XXX-tomcat":[{"color":"#FF4136","name":"XXX-tomcat-verify","url":"http://1.1.7.9:8080/job/xxx-tomcat-verify/"},{"color":"#FF4136","name":"XXX-tomcat-accept","url":"http://1.1.7.9:8080/job/xxx-tomcat-accept/"},{"color":"#FF4136","name":"XXX-tomcat-delivery","url":"http://1.1.7.9:8080/job/xxx-tomcat-delivery/"}],"XXX-linux":[{"color":"#FF4136","name":"XXX-linux-verify","url":"http://1.1.7.9:8080/job/xxx-tomcat-verify/"},{"color":"#FF4136","name":"XXX-linux-accept","url":"http://1.1.7.9:8080/job/xxx-tomcat-accept/"},{"color":"#FF4136","name":"XXX-linux-delivery","url":"http://1.1.7.9:8080/job/xxx-tomcat-delivery/"}]}
(index):81 [Object, Object]
(index):82 [{"key":"XXX-tomcat","values":[{"color":"#FF4136","name":"XXX-tomcat-verify","url":"http://1.1.7.9:8080/job/xxx-tomcat-verify/"},{"color":"#FF4136","name":"XXX-tomcat-accept","url":"http://1.1.7.9:8080/job/xxx-tomcat-accept/"},{"color":"#FF4136","name":"XXX-tomcat-delivery","url":"http://1.1.7.9:8080/job/xxx-tomcat-delivery/"}]},{"key":"XXX-linux","values":[{"color":"#FF4136","name":"XXX-linux-verify","url":"http://1.1.7.9:8080/job/xxx-tomcat-verify/"},{"color":"#FF4136","name":"XXX-linux-accept","url":"http://1.1.7.9:8080/job/xxx-tomcat-accept/"},{"color":"#FF4136","name":"XXX-linux-delivery","url":"http://1.1.7.9:8080/job/xxx-tomcat-delivery/"}]}]