0

我有两个看起来像这样的 JS 关联数组:

var distroDates = [
{
    name: 'exDate',
    data: [
        '06/25/2013',
        '12/17/2012',
        '06/20/2012',
        '12/19/2011',
        '06/21/2011',
        '12/20/2010',
        '06/21/2010',
        '12/21/2009',
        '06/22/2009',
        '12/22/2008',
        '06/23/2008',
        '12/24/2007',
        '12/21/2006',
        '12/23/2005',
        '12/23/2004',
        '12/22/2003',
        '12/23/2002'
    ]
},
{
    name: 'Record Date',
    data: [
        '06/27/2013',
        '12/19/2012',
        '06/22/2012',
        '12/21/2011',
        '06/23/2011',
        '12/22/2010',
        '06/23/2010',
        '12/23/2009',
        '06/24/2009',
        '12/24/2008',
        '06/25/2008',
        '12/27/2007',
        '12/26/2006',
        '12/28/2005',
        '12/28/2004',
        '12/24/2003',
        '12/26/2002'
    ]
},
{
    name: 'Payable Date',
    data: [
        '07/02/2013',
        '12/24/2012',
        '06/27/2012',
        '12/29/2011',
        '06/27/2011',
        '12/30/2010',
        '06/25/2010',
        '12/31/2009',
        '06/26/2009',
        '12/31/2008',
        '06/27/2008',
        '01/04/2008',
        '12/28/2006',
        '12/30/2005',
        '12/30/2004',
        '01/02/2004',
        '01/02/2003'
    ]
}
]
var distroData = [
{
    name: 'Income',
    data: [
        0.3908,
        0.4948,
        0.2311,
        0.3342,
        0.245,
        0.2213,
        0.19,
        0.1404,
        0.2014,
        0.2266,
        0.2131,
        0.2328,
        0.1288,
        0.0044,
        0.6248,
        0,
        0
    ]
},
{
    name: 'S.T. Capital Gains',
    data: [
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0
    ]
},
{
    name: 'L.T. Capital Gains',
    data: [
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0
    ]
},
{
    name: 'Return on Capital',
    data: [
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0,
        0.0202,
        0,
        0,
        0
    ]
}
]

distroData 数组用于该系列。distroDates 用于类别。我希望类别显示在工具提示中(而不是通常的系列数据),并且当我将鼠标悬停在 x 轴上的每个条形上时,我希望工具提示使用类别值进行更新。

以下代码使用 Highcharts v2.1.4/Highstock v1.2.5(均已加载)完成了此操作:

            tooltip: {
            formatter: function() {
                var s = '<table class="tooltip distro"><tbody>';
                var chart = this.points[0].series.chart; //get the chart object
                var categories = chart.xAxis[0].categories; //get the categories array
                var index = 0;
                var distroDataPoint;
                while(this.x !== categories[index]){index++;} //compute the index of corr y value in each data arrays
                $.each(distroDates, function(i, categories) { //loop through categories array
                    s += '<tr><td>'+ categories.name +':</td><td>' + categories.data[index] + '</td></tr>'; //use index to peg categories and distro data to series
                    distroDataPoint = '<tr><td>Distribution:</td><td>$' + distroData[0].data[index] + '</td></tr>';
                });
                s += distroDataPoint + '</tbody></table>'
                return s;
            },
            shared: true
        },

但是,当我升级到 Highstock 1.3.4(包括 Highcharts)时,while 语句锁定了我的浏览器(FF 和 Chrome)。浏览器给出了我认为熟悉的“脚本无响应”警报,因为它陷入了一个昂贵的循环。

有什么想法可以重写或替换 while 以使性能可以接受吗?

4

1 回答 1

0

为什么不直接使用共享工具提示?只需设置tooltip.shared = true,一切都会正常工作。在此处查看如何格式化共享工具提示的示例。

于 2013-08-08T10:45:18.633 回答