如何将json对象数据输入D3图表(例如气泡图,条形图)代替.JSON文件?

时间:2016-09-06 12:11:14

标签: javascript html json d3.js bubble-chart

  1. 我在js文件中有json对象(例如 MyFirstMashup.js )和我 已经在相同的js文件中复制了气泡图的脚本。在所有 在网络上可以使用的例子,他们使用了json文件,例如。 flare.json,xyz.tsv等我不能像我这样拥有这个文件 在 MyFirstMashup.js 文件中动态获取数据。相反,我 已将气泡图代码附加到我现有的js代码下方。但 不幸的是,泡泡图代码并没有专门用于 data.json()部分。我想我不必使用它,因为我已经 拥有JSON对象。如果不是那么需要在中编辑的内容 气泡图代码。带有气泡图的 MyFirstMashup.js part和json对象**(var jsonObj)**是---

    var jsonStr = JSON.stringify(matrix);
    var jsonObj = JSON.parse(jsonStr); // json对象

    var bubble = d3.layout.pack()
          .sort(null)
          .size([diameter, diameter])
          .padding(1.5);
    
    var svg = d3.select("body").append("svg")
          .attr("width", diameter)
          .attr("height", diameter)
          .attr("class", "bubble");
    
    d3.json("flare.json", function(error, root) { //hw to replace flare.json
        if (error) throw error;                   //with jsonObj(any json object)   
    
        var node = svg.selectAll(".node")
            .data(bubble.nodes(classes(root))
            .filter(function(d) { return !d.children; }))
          .enter().append("g")
            .attr("class", "node")
            .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; });
    
        node.append("title")
            .text(function(d) { return d.className + ": " + format(d.value); });
    
        node.append("circle")
            .attr("r", function(d) { return d.r; })
            .style("fill", function(d) { return color(d.packageName); });
    
        node.append("text")
            .attr("dy", ".3em")
            .style("text-anchor", "middle")
            .text(function(d) { return d.className.substring(0, d.r / 3); });
      });
    
     // Returns a flattened hierarchy containing all leaf nodes under the root.
      function classes(root) {
        var classes = [];
    
        function recurse(name, node) {
          if (node.children) node.children.forEach(function(child) { recurse(node.name, child); });
          else classes.push({packageName: name, className: node.name, value: node.size});
        }
    
        recurse(null, root);
        return {children: classes};
      }
    
      d3.select(self.frameElement).style("height", diameter + "px");
    

1 个答案:

答案 0 :(得分:1)

然后,您可以创建一个这样的渲染函数,而不是使用d3.json函数:

var jsonStr = JSON.stringify(matrix);
var jsonObj = JSON.parse(jsonStr); //json object

var bubble = d3.layout.pack()
      .sort(null)
      .size([diameter, diameter])
      .padding(1.5);

var svg = d3.select("body").append("svg")
      .attr("width", diameter)
      .attr("height", diameter)
      .attr("class", "bubble");

render(jsonObj); // And simply call it like this.

function render(root) {  

    var node = svg.selectAll(".node")
        .data(bubble.nodes(classes(root))
        .filter(function(d) { return !d.children; }))
      .enter().append("g")
        .attr("class", "node")
        .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; });

    node.append("title")
        .text(function(d) { return d.className + ": " + format(d.value); });

    node.append("circle")
        .attr("r", function(d) { return d.r; })
        .style("fill", function(d) { return color(d.packageName); });

    node.append("text")
        .attr("dy", ".3em")
        .style("text-anchor", "middle")
        .text(function(d) { return d.className.substring(0, d.r / 3); });
  };

// Returns a flattened hierarchy containing all leaf nodes under the root.
  function classes(root) {
    var classes = [];

    function recurse(name, node) {
      if (node.children) node.children.forEach(function(child) { recurse(node.name, child); });
      else classes.push({packageName: name, className: node.name, value: node.size});
    }

    recurse(null, root);
    return {children: classes};
  }



  d3.select(self.frameElement).style("height", diameter + "px");

或删除render函数并直接在.data(bubble.nodes(classes(jsonObj ))

中使用jsonObj
var jsonStr = JSON.stringify(matrix);
var jsonObj = JSON.parse(jsonStr); //json object

var bubble = d3.layout.pack()
      .sort(null)
      .size([diameter, diameter])
      .padding(1.5);

var svg = d3.select("body").append("svg")
      .attr("width", diameter)
      .attr("height", diameter)
      .attr("class", "bubble");  

var node = svg.selectAll(".node")
        .data(bubble.nodes(classes(jsonObj))
        .filter(function(d) { return !d.children; }))
      .enter().append("g")
        .attr("class", "node")
        .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; });

node.append("title")
        .text(function(d) { return d.className + ": " + format(d.value); });

node.append("circle")
        .attr("r", function(d) { return d.r; })
        .style("fill", function(d) { return color(d.packageName); });

node.append("text")
        .attr("dy", ".3em")
        .style("text-anchor", "middle")
        .text(function(d) { return d.className.substring(0, d.r / 3); });


// Returns a flattened hierarchy containing all leaf nodes under the root.
  function classes(root) {
    var classes = [];

    function recurse(name, node) {
      if (node.children) node.children.forEach(function(child) { recurse(node.name, child); });
      else classes.push({packageName: name, className: node.name, value: node.size});
    }

    recurse(null, root);
    return {children: classes};
  }



  d3.select(self.frameElement).style("height", diameter + "px");

示例小提琴:http://jsfiddle.net/mzz9B/47/