javascript - JSON、Codeigniter、Highcharts 和 AJAX

标签 javascript ajax json codeigniter highcharts

我正在使用 CI (+HMVC) 在表单上显示带有 ajax 事件的 Highcharts。

我的 pb 是为图表创建有效系列。我必须从 mysql DB 创建 6 系列。我的图表代码的灵感来自 blank page highchart in using jquery to call json arrary .

我的观点 ( <?=$instance_graph?> 无处不在,因为我希望能够实例化多个图表)

$(document).ready(function() {
    $('#submit<?=$instance_graph?>').click(function() {
        $('#rendu_graph<?=$instance_graph?>').html('');
        var form_data = {
        from : $('#from[name=from<?=$instance_graph?>]').val(),
        to : $('#to[name=to<?=$instance_graph?>]').val(),
        parametre : $('#parametre[name=parametres<?=$instance_graph?>]').val(),
        ajax : '1'
        };
        $.ajax({
            url: "<?= site_url('graph_meteo/ajax_graph'); ?>",
            type: 'POST',
            async : false,
            data: form_data,
            dataType:'json',
            success: function(data) {
            //alert(msg) ;
            //$('#rendu_graph<?=$instance_graph?>').html(msg);
            var chartSeriesData=[];
            $.each(data, function(i,item){
                var series_name = item.name;
                var series_data = item.data;     
                var series = {data: item.data,name:series_name};
                chartSeriesData.push(series);
            });
            console.log(chartSeriesData) ;
            chart = new Highcharts.Chart({ //Début du Highchar
            chart: {
                renderTo: 'rendu_graph<?=$instance_graph?>',
                type: 'spline'
            },
            title: {
                text: 'Graph' 
            },
            subtitle: {
                text: 'Title'
            },
            xAxis: {
                type: 'datetime'

            },
            yAxis: {
                title: {
                    text: 'param 1'
                }
            },
            tooltip: {
                formatter: function () {
                    return '<b>' + this.series.name + '</b><br/>' + Highcharts.dateFormat('%a %d %b %H:%M', this.x) + ': ' + this.y + ' m';
                }
            },

            series: chartSeriesData


        })

创建的系列的console.log:

[Object { data="[Date.UTC(2013,02,06,14,15),65.09375]",  name="Station 1"}, Object { data="[Date.UTC(2013,02,06,14,15),65.09375]",  name="Station 1"}, Object { data="[Date.UTC(2013,02,06,14,15),65.09375]",  name="Station 1"}, Object { data="[Date.UTC(2013,02,06,14,30),63.425]",  name="Station 1"}.

image

当然,我为每个没有情节的对象都有一个系列:

enter image description here

编辑:我正在寻找一种方法来使用这些数据(1行)制作一个漂亮的工作图表,并且我希望我的代码适用于许多行/系列。我的大PB是从查询结果开始到图表系列格式。一个例子可能是很好的答案。

希望你能在我生气之前帮助我!

最佳答案

您的设置的第一个问题是每个系列的数据都是一个带有数组的字符串。目前看起来像:

{ data: "[Date.UTC(2013,02,06,14,15),65.09375]",  name: "Station 1"}

名称看起来不错,但数据应该是真正的 JavaScript 数组,而不是字符串。这就是您想要的样子:

{ data: [Date.UTC(2013,02,06,14,15),65.09375],  name: "Station 1"}

当这个问题解决后,我认为你应该将所有数据点放在同一个系列定义中。所以代替:

{ data: [Date.UTC(2013,02,06,14,15),65.09375],  name: "Station 1"},
{ data: [Date.UTC(2013,02,07,14,15),67.09375],  name: "Station 1"}

你应该有一个包含很多点的系列:

{ data: [
      [Date.UTC(2013,02,06,14,15),65.09375],
      [Date.UTC(2013,02,07,14,15),67.09375],
      <more data points here>],
  name="Station 1"},

关于javascript - JSON、Codeigniter、Highcharts 和 AJAX,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14741325/

相关文章:

javascript - 如何从 ajax 数据绘制 highstock 单线系列图

javascript - 如何将项目光滑网格添加到多选文本框?

python:如何使用 ijson 库解析 json 数组流

java - 如何从 Spring Security 中的过滤器向 header 添加值?

java - 在 Spring 中接受任意 JSON 作为 RequestBody

php - 刷新时交换两个不同的图像/div

javascript - 在多个地方点击来回交换图像

javascript - JS : Get the . 所选数据列表选项的 html()

javascript - 来自 Ajax 请求的 HTML 表

jquery - ie7 AJAX 函数期望的标识符、字符串或数字