用 Chart.js 填充每个 JsonRPC 获取的数据绘制图表

Drawing chart with Chart.js filled with data gotten per JsonRPC

我想从每个 JavaScript 对 PHP 服务器的 JsonRPC 调用中获取结果以供进一步使用(使用 Chart.js 绘制图表)。 为此,我有一个函数应该执行调用并 return 结果。 我使用这个 jQuery 插件:https://github.com/datagraph/jquery-jsonrpc

$.jsonRPC.setup({
    endPoint: '/jsonserver.php'
});

var res; // first place
function getMyStuff() {
    var res; // second place as alternative
    $.jsonRPC.request('getResultsById', {
        params: [1],
        success: function(result) {
            alert(JSON.stringify(result, null, 4)); // works well
            res = result;
        },
        error: function(result) {
            alert("error: " + JSON.stringify(result, null, 4));
        }
    });
    return res;
}

我的问题是我不知道如何从成功块中获取结果。如果我调用该函数,我总是得到 undefined。

请求是异步处理的,因此您需要提供回调,就像您在 'success' 和 'error' 块中所做的那样。可能最简单的方法就是提供另一个回调来调用结果,如下所示:

$.jsonRPC.setup({
    endPoint: '/jsonserver.php'
});

getMyStuff(function (result) {
    console.log("here's the result", result);
});

function getMyStuff(callback) {
    $.jsonRPC.request('getResultsById', {
        params: [1],
        success: callback,
        error: function(result) {
            console.error("error:", result);
        }
    });
}

谢谢大家的指点。
对于每个 运行 遇到同样问题的人——我的工作代码示例:

$.jsonRPC.setup({
    endPoint: '/jsonserver.php'
});

drawMyChart(function (result) {
    var ctx = document.getElementById("canvas").getContext("2d");
    var lineChartData = {
        labels: makeSuitableArrayLabel(result),
        datasets : [
            {
                fillColor : "#F06292",
                data: makeSuitableArrayFirst(result)
            },
            {
                fillColor : "#1565C0",
                data: makeSuitableArraySecond(result)
            }
        ]
    };

    window.myLine = new Chart(ctx).Line(lineChartData, {
        // options
    });
});

function drawMyChart(callback) {
    $.jsonRPC.request('getResultsById', {
        params: [1],
        success: callback,
        error: function(result) {
            console.error("error:", result);
        }
    });
}

// add
$("#add").click(function() {
    myLine.addData([1, 2], "label");
});