当我更新现有 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 值以固定值递增——所以我只能认为在重绘图表时我遗漏了一些东西。