使用discreteBarChart nvd3.js中的数据自定义工具提示的工具提示内容

时间:2014-03-28 12:51:00

标签: javascript d3.js tooltip nvd3.js

如何使用加载到discreteBarChart nvd3.js中的“datum”中的数据来自定义工具提示的工具提示内容,例如,使用以下数据Jason,我想在工具提示中看到data3,data4,Data5

JsonData = [ 
             {
               key: "Serie1",
               values: [
                         {'Data1':  1, 
                          'Data2':  2, 
                          'Data3':  3,
                          'Data4':  4,
                          'Data5':  5
                         }
                       ]
             }
           ];

2 个答案:

答案 0 :(得分:7)

这是怎么做的:

nv.addGraph(function() {  
   var chart = nv.models.discreteBarChart()
      .x(function(d) { return d.Data1 })
      .y(function(d) { return d.Data2 })
      .tooltips(true)
      .tooltipContent(function(key, y, e, graph) {
       var data =graph.series.values[y-1];
       return  '<p> Text1: ' +  data.Data3 + '</p>'
             + '<p> Text2: ' +  data.Data4 + '</p>'
             + '<p> Text3: ' +  data.Data5 + '</p>'
       });

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

   nv.utils.windowResize(chart.update);

   return chart;
});

答案 1 :(得分:3)

我想出了类似的东西,因为图形对象有一个值属性:

chart.tooltipContent(function (key, date, e, graph) {
     var value = graph.value;
     return  "<p><strong>" + date + "</strong><br>" + value + "</p>";
});

我猜不需要访问系列数组。