如何在用户点击时确定条形图(Highchart)中栏的值?

时间:2012-07-02 21:26:23

标签: javascript html ruby-on-rails ruby

目前我有一个根据我数据库中的数据呈现的Highchart。当我手动传递诸如“A”或“C”之类的值时,我当前还有一个使用正确值呈现的表,但我希望该表根据onClick事件进行呈现,当用户单击时我的Highchart中的酒吧。

对于下面的每个对应值,例如@a_sum,我有一个名为@a的数组,其中包含将传递给图表的字符串值。

我没有太多运气就google了。我想知道当用户点击该特定栏时,我如何获得char中栏的值。

非常感谢任何帮助。

<script type="text/javascript" charset="utf-8">
var chart1; // globally available
$(document).ready(function () {
    var chart = new Highcharts.Chart({
        chart: {
            renderTo: 'container',
            type: 'bar'
        },
        title : {
            text: "Most Effective Referral Sources"
        },
        xAxis: {
            categories: ['A', 'B', 'C', 'D', 'E', 'F',  'G', 'H', 'I', 'J', 'K', 'L']
        },
        yAxis: {   
        },
        legend: {
            layout: 'vertical',
            floating: true,
            backgroundColor: '#FFFFFF',
            align: 'right',
            verticalAlign: 'top',
            y: 60,
            x: -60
        },
        tooltip: {
            formatter: function() {
                return '<b>'+ this.series.name +'</b><br/>'+
                    this.x +': '+ this.y;
            }
        },
        plotOptions: {
        },
        series: [{
            data: [<%= @a_sum %>, <%= @b_sum %>, <%= @c_sum %>, <%= @d_sum %>,  <%= @e_sum %>, <%= @f_sum %>, <%= @g_sum %>, <%= @h_sum %>, <%= @i_sum %>, <%= @j_sum %>,  <%= @k_sum %>, <%= @l_sum %>]
        }]
    });
});

</script>

1 个答案:

答案 0 :(得分:1)

看起来你想要的(如果我理解你正确的问题)是在上面的plotOptions中实现事件:     http://www.highcharts.com/ref/#plotOptions-column-point-events--click

plotOptions: {
    column: {
         point: {
             events: {
         click: function() {
                     // use this to trigger showing/hiding the specific table you need
                     console.log(this)
                 }
             }
         }
    }
}

例如,这是我得到的控制台日志的示例:

Lc
_high: 417
...
series: c
...
x: 20
y: 33
__proto__: Object

使用this.series,您应该能够获取单击其列的系列上的参数,然后调用“enableTableForDataSeries”函数以启用特定数据系列。