首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >多系列高库存实时图表

多系列高库存实时图表
EN

Stack Overflow用户
提问于 2015-06-18 00:48:36
回答 1查看 544关注 0票数 0

我已经有了一个实时的实时图形,其中一个系列正在工作。就像this tutorial一样。

这是我的js代码。

代码语言:javascript
复制
<script>
var chart;
function requestData() {
    $.ajax({
        url: 'live-server-data.php',
        success: function(point) {
            var series = chart.series[0],
                shift = series.data.length > 20;
            chart.series[0].addPoint(point, true, shift);
            setTimeout(requestData, 1000);    
        },
        cache: false
    });
}
</script>

这是live-server-data.php传递的JSON

代码语言:javascript
复制
[1430687116000,994]

如何将js脚本绘制成多个系列?我的猜测是迭代传递的JSON数组并添加每个系列的点,但不知道如何在js、jquery、ajax或我必须使用的任何东西上实现它。

EN

回答 1

Stack Overflow用户

发布于 2015-06-18 16:35:32

你需要两样东西:

1)服务器应在该请求中返回更多信息,例如:

代码语言:javascript
复制
[ [1430687116000, 994], [1430687116000, 5], ... , [1430687116000, 11] ]

或者更好的格式,只提供一次时间戳:

代码语言:javascript
复制
{
    "timestamp": 1430687116000,
    "points": [ 994, 5, ... , 11 ]
}

2)现在只需更新所有系列:

代码语言:javascript
复制
$.ajax({
    url: 'live-server-data.php',
    success: function(points) {
        var series = chart.series,
            shift;

        $.each(series, function(i, s) {
            shift = s.data.length > 20;
            s.addPoint(points[i], false, shift);
        });
        setTimeout(requestData, 1000);   
        chart.redraw(); 
    },
    cache: false
});

或者对于JSON的另一种格式,它将是:

代码语言:javascript
复制
$.ajax({
    url: 'live-server-data.php',
    success: function(points) {
        var series = chart.series,
            shift;

        $.each(series, function(i, s) {
            shift = s.data.length > 20;
            s.addPoint([points.timestamp, points.data[i]], false, shift);
        });
        setTimeout(requestData, 1000);   
        chart.redraw(); 
    },
    cache: false
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30897683

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档