3

我正在使用 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 位。

这可能吗?

4

2 回答 2

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.

于 2013-10-17T10:43:30.770 回答
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 的东西,你就会被它提供给你的数据所困。我认为这样做的一个好方法是为工具提示 x 格式化程序或其他东西设置一个设置器,然后它将在轴格式化程序上使用它。或者只是将原始数据连同值和序列一起发送。

我的用例是我在图表上显示 7 天的时间刻度,我只勾选每天的开始。但是,在工具提示中,我想更详细地了解该数据。

这是我特定于指南工具提示的拉取请求

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

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

于 2014-02-12T23:18:19.657 回答