4

当我更新现有 NVD3 图表中的数据时,沿 x 轴的刻度不会以固定间隔呈现。

我正在创建一个multiBarChart来自d3.json(). 数据代表一个日期范围内的命中。我有一个单独的日期范围选择器来更新图表的数据。

我有以下创建图表(简化):

initGraph = function(url) {
  d3.json(url, function(data) {
    nv.addGraph(function() {
      chart = nv.models.multiBarChart();

      d3.select('#chart svg').datum(data).transition().duration(500).call(chart);
      nv.utils.windowResize(chart.update);

      return chart;
    });
  });
};

以及以下更新它的函数,它在日期选择器中调用:

redrawGraph = function(url) {
  d3.json(url, function(data) {

    d3.select('#chart svg').datum(data).transition().duration(500).call(chart);
    nv.utils.windowResize(chart.update);
  });
};

一切似乎都很好,但有时刻度间距会不一致:

古怪的蜱虫

这仅在更新现有图表时发生。

我花了很长时间验证数据是否正确——x 值以固定值递增——所以我只能认为在重绘图表时我遗漏了一些东西。

4

2 回答 2

3

有点晚了,但是你需要调用chart.update()而不是注册一个新的窗口监听器,这样代码就变成了:

redrawGraph = function(url) {
  d3.json(url, function(data) {

    d3.select('#chart svg').datum(data).transition().duration(500).call(chart);
    chart.update();
  });
};

基本上每次更新 nvd3 中的图表时,都需要调用chart.update重新绘制它。

请注意,nv.utils.windowResize(chart.update)这相当于

// Register an event listener on windowResize
nv.utils.windowResize(function() {
  // Every time the window is resized, redraw the chart
  chart.update();
});

所以每次更新都这样做不会有好的效果。

于 2015-02-19T00:49:12.480 回答
1

我已经通过在选择日期范围时重新创建图表来解决这个问题:

$("#chart svg").empty();

结果并不像人们想象的那么糟糕。

于 2013-02-12T07:54:35.693 回答