繁体   English   中英

jQuery Flot图形图工具提示

[英]jQuery flot graph plot tooltip

我有一个显示如下的图形:

图形

我希望工具提示显示“ 31/07的销售额为1500英镑”,而不是4。

我的x轴是这样生成的:

xaxis: {
    tickColor: 'transparent',
    tickDecimals: 0,
    ticks: [[1,'27/07'],[2,'28/07'],[3,'29/07'],[4,'30/07'],[5,'31/07'],[6,'01/08'],[7,'02/08']]
},

生成工具提示的代码是:

function showTooltip(x, y, contents) {
    jQuery('<div id="tooltip">' + contents + '</div>').css({
        top: y - 16,
        left: x + 20
    }).appendTo('body').fadeIn();
}

var previousPoint = null;

jQuery('#graph-lines, #graph-bars').bind('plothover', function (event, pos, item) {
    if (item) {
        if (previousPoint != item.dataIndex) {
            previousPoint = item.dataIndex;
            jQuery('#tooltip').remove();
            var x = item.datapoint[0],
                y = item.datapoint[1];
                showTooltip(item.pageX, item.pageY, '&pound;' + y + ' sales on ' + x);
        }
    } else {
        jQuery('#tooltip').remove();
        previousPoint = null;
    }
});

重要的一行是:

var x = item.datapoint[0]

我怎样才能读取刻度线而不是值?

谢谢

我已经弄清楚了,我意识到我需要在数据点中保存x轴标签:

var graphData = [{
        // Shop
        data: [ [1, 1300, '27/07'], [2, 1600, '28/07'], [3, 1700, '29/07'], [4, 1500, '30/07'], [5, 1500, '31/07'], [6, 1200, '01/08'], [7, 1000, '02/08'] ],
        color: '#71c73e'
    }, {
        // Net
        data: [ [1, 900, '27/07'], [2, 1100, '28/07'], [3, 1550, '29/07'], [4, 1600, '30/07'], [5, 1800, '31/07'], [6, 1400, '01/08'], [7, 1300, '02/08'] ],
        color: '#77b7c5',
        points: { radius: 4, fillColor: '#77b7c5' }
    }
];

然后替换为:

var x = item.datapoint[0]

有了这个:

var x = item.series.data[item.dataIndex][2]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM