Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/14.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 修改d3.js圆环图以从json数组读取_Javascript_Json_D3.js - Fatal编程技术网

Javascript 修改d3.js圆环图以从json数组读取

Javascript 修改d3.js圆环图以从json数组读取,javascript,json,d3.js,Javascript,Json,D3.js,如何修改此示例以从JSON数组而不是CSV文件读取?我将有一个静态JSON字符串,我希望将其用作“数据”而不是CSV。任何指点都将不胜感激 var width = 960, height = 500, radius = Math.min(width, height) / 2; var color = d3.scale.ordinal() .range(["#98abc5", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8

如何修改此示例以从JSON数组而不是CSV文件读取?我将有一个静态JSON字符串,我希望将其用作“数据”而不是CSV。任何指点都将不胜感激

var width = 960,
height = 500,
radius = Math.min(width, height) / 2;

var color = d3.scale.ordinal()
.range(["#98abc5", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8c00"]);

var arc = d3.svg.arc()
.outerRadius(radius - 10)
.innerRadius(radius - 70);

var pie = d3.layout.pie()
.sort(null)
.value(function(d) { return d.population; });

var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height)
.append("g")
.attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");

d3.csv("data.csv", type, function(error, data) {
if (error) throw error;

var g = svg.selectAll(".arc")
  .data(pie(data))
.enter().append("g")
  .attr("class", "arc");

 g.append("path")
  .attr("d", arc)
  .style("fill", function(d) { return color(d.data.age); });

 g.append("text")
  .attr("transform", function(d) { return "translate(" + arc.centroid(d) + ")"; })
  .attr("dy", ".35em")
  .text(function(d) { return d.data.age; });
});

function type(d) {
d.population = +d.population;
return d;
}
示例JSON数据:

[
{
"age": "<5",
"population": 2704659
},
{
"age": "5-13",
"population": 4499890
},
{
"age": "14-17",
"population": 2159981
},
{
"age": "18-24",
"population": 3853788
},
{
"age": "25-44",
"population": 14106543
},
{
"age": "45-64",
"population": 8819342
},
{
"age": "≥65",
"population": 612463
}
]
[
{

“年龄”:“只需使用
d3.json

var data; // a global

d3.json("path/to/file.json", function(error, json) {
  if (error) return console.warn(error);
  data = json;
  visualizeit();
});
这里有更多关于

编辑 如果您不想加载外部json,这里有一个

您所要做的就是放弃
d3.json
调用并声明
var data=[…]

基本上,剩下的是:

    var width  = 960,
        height = 500,
        radius = Math.min(width, height) / 2;

    var color = d3.scale.ordinal()
        .range(["#98abc5", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8c00"]);

    var arc = d3.svg.arc()
        .outerRadius(radius - 10)
        .innerRadius(radius - 70);

    var pie = d3.layout.pie()
        .sort(null)
        .value(function (d) {
            return d.population;
        });

    var svg = d3.select("body").append("svg")
        .attr("width", width)
        .attr("height", height)
        .append("g")
        .attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");

    data = [
        {
            "age": "<5",
            "population": 2704659
        },
        {
            "age": "5-13",
            "population": 4499890
        },
        {
            "age": "14-17",
            "population": 2159981
        },
        {
            "age": "18-24",
            "population": 3853788
        },
        {
            "age": "25-44",
            "population": 14106543
        },
        {
            "age": "45-64",
            "population": 8819342
        },
        {
            "age": "≥65",
            "population": 612463
        }
    ];

    var g = svg.selectAll(".arc")
        .data(pie(data))
        .enter().append("g")
        .attr("class", "arc");

    g.append("path")
        .attr("d", arc)
        .style("fill", function (d) {
            return color(d.data.age);
        });

    g.append("text")
        .attr("transform", function (d) {
            return "translate(" + arc.centroid(d) + ")";
        })
        .attr("dy", ".35em")
        .text(function (d) {
            return d.data.age;
        });

    function type(d) {
        d.population = +d.population;
        return d;
    }
var-width=960,
高度=500,
半径=数学最小值(宽度、高度)/2;
var color=d3.scale.ordinal()
.范围([“98abc5”、“8a89a6”、“7b6888”、“6b486b”、“a05d56”、“d0743c”、“ff8c00”);
var arc=d3.svg.arc()
.外层(半径-10)
.内半径(半径-70);
var pie=d3.layout.pie()
.sort(空)
.价值(功能(d){
返回d.population;
});
var svg=d3.选择(“正文”).追加(“svg”)
.attr(“宽度”,宽度)
.attr(“高度”,高度)
.附加(“g”)
.attr(“变换”、“平移”(+width/2+)、“+height/2+”);
数据=[
{

“年龄”:“只需使用
d3.json

var data; // a global

d3.json("path/to/file.json", function(error, json) {
  if (error) return console.warn(error);
  data = json;
  visualizeit();
});
这里有更多关于

编辑 如果您不想加载外部json,这里有一个

您所要做的就是放弃
d3.json
调用并声明
var data=[…]

基本上,剩下的是:

    var width  = 960,
        height = 500,
        radius = Math.min(width, height) / 2;

    var color = d3.scale.ordinal()
        .range(["#98abc5", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8c00"]);

    var arc = d3.svg.arc()
        .outerRadius(radius - 10)
        .innerRadius(radius - 70);

    var pie = d3.layout.pie()
        .sort(null)
        .value(function (d) {
            return d.population;
        });

    var svg = d3.select("body").append("svg")
        .attr("width", width)
        .attr("height", height)
        .append("g")
        .attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");

    data = [
        {
            "age": "<5",
            "population": 2704659
        },
        {
            "age": "5-13",
            "population": 4499890
        },
        {
            "age": "14-17",
            "population": 2159981
        },
        {
            "age": "18-24",
            "population": 3853788
        },
        {
            "age": "25-44",
            "population": 14106543
        },
        {
            "age": "45-64",
            "population": 8819342
        },
        {
            "age": "≥65",
            "population": 612463
        }
    ];

    var g = svg.selectAll(".arc")
        .data(pie(data))
        .enter().append("g")
        .attr("class", "arc");

    g.append("path")
        .attr("d", arc)
        .style("fill", function (d) {
            return color(d.data.age);
        });

    g.append("text")
        .attr("transform", function (d) {
            return "translate(" + arc.centroid(d) + ")";
        })
        .attr("dy", ".35em")
        .text(function (d) {
            return d.data.age;
        });

    function type(d) {
        d.population = +d.population;
        return d;
    }
var-width=960,
高度=500,
半径=数学最小值(宽度、高度)/2;
var color=d3.scale.ordinal()
.范围([“98abc5”、“8a89a6”、“7b6888”、“6b486b”、“a05d56”、“d0743c”、“ff8c00”);
var arc=d3.svg.arc()
.外层(半径-10)
.内半径(半径-70);
var pie=d3.layout.pie()
.sort(空)
.价值(功能(d){
返回d.population;
});
var svg=d3.选择(“正文”).追加(“svg”)
.attr(“宽度”,宽度)
.attr(“高度”,高度)
.附加(“g”)
.attr(“变换”、“平移”(+width/2+)、“+height/2+”);
数据=[
{

“年龄”:“实际上没有太多变化。使用您给出的示例,只需定义一个名为
data
的变量,并将您的示例JSON数据分配给它:

var data = [
{
  "age": "<5",
  "population": 2704659
},
{
  "age": "5-13",
  "population": 4499890
 },
...etc
var数据=[
{

“年龄”:“实际上没有太多变化。使用您给出的示例,只需定义一个名为
data
的变量,并将您的示例JSON数据分配给它:

var data = [
{
  "age": "<5",
  "population": 2704659
},
{
  "age": "5-13",
  "population": 4499890
 },
...etc
var数据=[
{

“age”:“我没有在本地保存我的文件。我将使用上面定义的json样式数组。因此var data=[{“age”:“@konrad here you go:)我没有在本地保存我的文件。我将使用上面定义的json样式数组。因此var data=[{“age”:“@konrad here you go:)