d3.js图表​​不会显示使用tsv文件

时间:2016-12-14 05:19:22

标签: javascript d3.js

我是d3js noobie所以请耐心等待我。我正在关注Mike Bostock的step-by-step tutorial如何使用外部数据文件创建条形图。我使用的文件格式为tsv,我通过将数据输入Excel创建,将其保存为txt文件,然后将扩展名重命名为tsv。然后,我根据this SO answer

设置python -m SimpleHTTPServer的本地网络服务器

虽然所有文件都出现在目录列表中,但条形图仍然不存在。我的控制台中没有出现错误。我想知道在我的tsv文件中如何将值分开是一个问题,尽管它看起来与示例相同。我非常感谢任何帮助,因为我渴望开始使用d3js。

编辑:我不确定这是否相关,但本地服务器上的文件显示在以下地址:http://0.0.0.0:8000/

这是js(直接从教程中复制):               

.chart rect {
  fill: steelblue;
}

.chart text {
  fill: white;
  font: 10px sans-serif;
  text-anchor: end;
}

</style>
<svg class="chart"></svg>
<script src="https://d3js.org/d3.v4.min.js" charset="utf-8">
<script>

var width = 420,
    barHeight = 20;

var x = d3.scale.linear()
    .range([0, width]);

var chart = d3.select(".chart")
    .attr("width", width);

d3.tsv("data2.tsv", type, function(error, data) {
  x.domain([0, d3.max(data, function(d) { return d.value; })]);

  chart.attr("height", barHeight * data.length);

  var bar = chart.selectAll("g")
      .data(data)
    .enter().append("g")
      .attr("transform", function(d, i) { return "translate(0," + i * barHeight + ")"; });

  bar.append("rect")
      .attr("width", function(d) { return x(d.value); })
      .attr("height", barHeight - 1);
d
  bar.append("text")
      .attr("x", function(d) { return x(d.value) - 3; })
      .attr("y", barHeight / 2)
      .attr("dy", ".35em")
      .text(function(d) { return d.value; });
});

function type(d) {
  d.value = +d.value; // coerce to number
  return d;
}

</script>

和tsv文件:

name    value
Locke   4
Reyes   8
Ford    15
Jarrah  16
Shephard    23
Kwon    42

1 个答案:

答案 0 :(得分:1)

最有可能出现两个问题:

  1. 您不会关闭此标记:

    <script src="https://d3js.org/d3.v4.min.js" charset="utf-8">

  2. d3.js v4将命名空间从d3.js v3中弄平,所以:

    var x = d3.scale.linear()

  3. 应为:

     var x = d3.scaleLinear()