我正在使用 nvd3 绘制一个简单的折线图,其中数据通过 ajax 请求接收。它与第一个绘图请求完美配合,但不适用于重绘。图表通过调用相同的绘图函数但使用不同的数据 + 不同的最大/最小值来重绘。
使用新数据重新绘制图表时,不会出现“悬停圆圈”,而工具提示会出现。此外,当单击图表的图例并通过再次出现悬停来强制重绘时,但 yAxis 的值将更改为第一个绘制的图表的值。
到目前为止,我假设重绘图表时仍然保留旧的最大/最小值 - 但仅涉及“悬停”效果。到目前为止,一般图表在重绘时看起来也很好 - 问题只是面临悬停,就是这样。
听起来很混乱,但希望你能明白这一点。
一些代码:
d3.json(queryurl, function(data2){
nv.addGraph(function(jsonData) {
if(chart){
chart.remove();
}
chart = nv.models.lineChart()
.x(function(d) { return d[0] })
.y(function(d) { return d[1] })
.color(d3.scale.category10().range());
chart.xAxis
.tickFormat(function(d) {
return d3.time.format('%x')(new Date(d))
});
chart.yAxis
.scale()
.tickFormat(d3.format(''));
chart.lines.yDomain([maxmin.max,maxmin.min]);
d3.select('#chart1 #chartsvg')
.datum(data2)
.transition().duration(600)
.call(chart);
nv.utils.windowResize(chart.update);
});
});
return chart;}