使用ajax使用flot绘制多个数据集 - 数据未正确显示

Dut*_*432 6 ajax jquery flot

我正在使用flot试图绘制一些数据.我使用单个数据集,当我尝试修改代码以使用多个数据集时,我遇到了一个错误,我很难跟踪并停止工作.我确信这是我所做的改变,但对于我的生活,我无法追踪它.

Y轴显示-1.0,-0.5,0,0.5和1.0 - 几乎没有我期望的值,也没有X轴数据.该图显示为空白.

我试图在StackOverflow上完成类似于信誉图的操作,但这将代表不同的数值.该data对的第一个值是一个时间戳(我想我已正确计算),该data对的第二个值是要绘制的值.

我确保我没有引号中的值,我看到这是最常见的问题之一.

任何有关指出问题的反馈或帮助都将非常感激.

stats.js

function plotField(){
    var field = 'activeUsers,totalUsers';
    var url = '/api/consoleGet_stats?field='+field;
    $.ajax({
        url: url,
        method: 'GET',
        dataType: 'json',
        success: function(datasets){
            var i = 0;
            console.log(datasets);
            $.each(datasets, function(key, val){
                val.color=i;
                i++;

                var data = [ $(this) ];
                console.log(data);

                var options = {
                    lines: { show: true },
                    points: { show: true },
                    xaxis: {mode: 'time', timeformat: "%y/%m/%d", tickDecimals: 0, tickSize: 1 }
                };

                var placeholder = $("#placeholder");

                $.plot(placeholder, data, options);
            });
        }
    });   
}
Run Code Online (Sandbox Code Playgroud)

consoleGet_stats.php

<?php
    //simplified for example purposes
    $fields=explode(",",$_REQUEST['field']);

    foreach ($fields as $field){
        $rows=$dbConnect->getRows('select date, ' .$field. ' from websiteStats order by id asc');
        $resultData = array('label' => $field);
        foreach($rows as $row){
            $t = strtotime($row['date']." UTC") * 1000;
            $resultData['data'][]=array($t, (int)$row[$field]);
        }
        $results[]=$resultData;
    }
    die(Json_encode($results));
?>
Run Code Online (Sandbox Code Playgroud)

控制台输出

[Object { label="activeUsers", data=[6]}, Object { label="totalUsers", data=[6]}]
[[Object { label="activeUsers", data=[6], color=0}]]
[[Object { label="totalUsers", data=[6], color=1}]]
Run Code Online (Sandbox Code Playgroud)

从firebug返回json(为此帖子添加了格式)

[
    {"label":"activeUsers","data":[[1334583090000,26],[1334669491000,26],[1334755893000,26],[1334842290000,26],[1334928691000,26],[1335015093000,26]]},
    {"label":"totalUsers","data":[[1334583090000,150],[1334669491000,170],[1334755893000,193],[1334842290000,200],[1334928691000,225],[1335015093000,257]]}
]
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

Dut*_*432 4

我能够通过将代码更改为更简化来解决该问题:

function plotField(){
    var field = 'activeUsers,totalUsers';
    var url = '/api/consoleGet_stats?field='+field;
    $.ajax({
        url: url,
        method: 'GET',
        dataType: 'json',
        success: function(datasets){
            $.plot($("#placeholder"), datasets);
        }
    });   
}
Run Code Online (Sandbox Code Playgroud)