NVD3.js y轴和工具提示的精度不同

时间:2013-10-17 10:34:44

标签: javascript d3.js nvd3.js

我正在使用NVD3.js来显示多线图。

我希望yAxis显示为2个十进制数

编辑回答

 var chart;

    nv.addGraph(function () {
        chart = nv.models.lineChart()
        .options({
            margin: { left: 140, bottom: 50 },
            x: function (d, i) {
                return i;
            },
            showXAxis: true,
            showYAxis: true,
            transitionDuration: 250,
            tooltips: true,
            tooltipContent: function (key, x, y, e, graph) {
                return '<h3>' + key + '</h3>' +
                       '<p>' + e.point.y + ' at ' + x + '</p>'
            }
        });

        // chart sub-models (ie. xAxis, yAxis, etc) when accessed directly, return themselves, not the parent chart, so need to chain separately
        chart.xAxis
            .axisLabel("Maturity")
            .tickFormat(function(d) { return pivotedData[0].values[d].x; });

        chart.yAxis
            .axisLabel('Model Spread').tickFormat(d3.format(',.2f'));


        d3.select('#chart1 svg')
          .datum(pivotedData)
          .call(chart);

        //TODO: Figure out a good way to do this automatically
        nv.utils.windowResize(chart.update);

        chart.dispatch.on('stateChange', function (e) { nv.log('New State:', JSON.stringify(e)); });

        return chart;
    });

但是在线上的工具提示中我想显示12位小数。

这可能吗?

2 个答案:

答案 0 :(得分:5)

您可以设置被调用的函数,以通过图表对象的.tooltipContent格式化工具提示的内容。默认功能定义如下。

tooltip = function(key, x, y, e, graph) {
    return '<h3>' + key + '</h3>' +
           '<p>' +  y + ' at ' + x + '</p>'
}

您可以根据自己的喜好格式化y的值。请注意,y定义为

yAxis.tickFormat()(lines.y()(e.point, e.pointIndex))

这意味着轴的刻度格式会影响它,因此为了获得更高的精度,您需要直接获取值 - lines可以通过chart.lines访问。

答案 1 :(得分:0)

在nvd3源中,他们有这样的行(折线图):

 interactiveLayer.dispatch.on('elementMousemove', function(e) {
  ...
      var xValue = xAxis.tickFormat()(chart.x()(singlePoint,pointIndex));
      interactiveLayer.tooltip
              .position({left: pointXLocation + margin.left, top: e.mouseY + margin.top})
              ...
              .valueFormatter(function(d,i) {
                 return yAxis.tickFormat()(d);
              })
              .data(
                  {
                    value: xValue,
                    series: allData
                  }
              )();
...
}

因此,如果您想覆盖像tooltip.contentGenerator这样的内容,那么您就会遇到它所提供的数据。我认为这样做的一个好方法是为tooltip x formatter设置一个setter,然后它会在轴格式化器上使用它。或者只是将原始数据与值和系列一起发送。

我的用例是我在图表上显示7天的时间刻度我只记录每天的开始。但是在工具提示中,我想提供更详细的数据视图。

以下是针对指南工具提示的拉取请求

https://github.com/novus/nvd3/pull/444

调用:chart.tooltipXAxisFormatter(d3.time.format(toolTipFormat));将设置它。