showing undefined data in chart.js but showing array in inspect element

喜你入骨 提交于 2019-12-25 03:30:33

问题


I am trying to display total montly sales of a financial april to march of a year. I am using chart.js and codeigniter for this ..

I have tried query in phpmyadmin , and giving me columns there, the same array is displaying in console log but when I run chartjs. It shows me undefined. Also I have written query for displaying last years data, but it is giving me one column of 2015, dont know how it is comming there.

<<>> added edit- i tried google charts, morris charts, highcharts, charts.js, jpgraph, and few others. its not displaying bar graph :( please help me .. how to know whats going wrong in it..?

My Model --

function getRetailYtd() 
    {
    $query = $this->db->query("select
    DATE_FORMAT(created_on, '%b-%Y') AS month,
         SUM(total_amount) as total 
    FROM
        orders 
    WHERE
        dispatched_on >= CONCAT(YEAR(NOW()), '-04-01') - INTERVAL 1 YEAR
        AND dispatched_on  < CONCAT(YEAR(NOW()), '-04-01')
    GROUP BY
        DATE_FORMAT(created_on, '%m-%Y') 
    ORDER BY
        DATE_FORMAT(created_on, '%Y-%m') DESC");
        return $query->result_array();
    }

My Controller-

function retail_ytd_data(){
  $this->load->model('dashboard_model','dm');
  $data  = $this->dm->getRetailYtd();
  $this->load->view('retail_ytd');
  print_r(json_encode($data, true));

  }

My View-

<div id="chart-container">
  <canvas id="mycanvas"></canvas>
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script src="//cdn.jsdelivr.net/npm/chart.js@2.8.0/dist/Chart.min.js"></script>
<script src='<?php echo base_url();?>assets/global/scripts/app.js'></script>

App.js--

     $(document).ready(function(){
  $.ajax({
    url: "http://localhost/project5/flow/retail_ytd_data",
    method: "GET",
    success: function(data) {
      console.log(data);
      var month = [];
      var total = [];

     for(var i in data) {
        month.push("month " + data[i].month);
        total.push(data[i].total);
      }

      var chartdata = {
        labels: month,
        datasets : [
          {
            label: 'month total',
            backgroundColor: 'rgba(200, 200, 200, 0.75)',
            borderColor: 'rgba(200, 200, 200, 0.75)',
            hoverBackgroundColor: 'rgba(200, 200, 200, 1)',
            hoverBorderColor: 'rgba(200, 200, 200, 1)',
            data: total
          }
        ]
      };

      var ctx = $("#mycanvas");

      var barGraph = new Chart(ctx, {
        type: 'bar',
        data: chartdata
      });
    },
    error: function(data) {
      console.log(data);
    }
  });
});

Inspect element in network showing- >

[{"month":"Mar-2019","total":"2127.40"},{"month":"Feb-2019","total":"7906.00"},{"month":"Jan-2019","total":"586.89"},{"month":"Dec-2018","total":"7200.10"},{"month":"Apr-2018","total":"16234.39"},{"month":"Mar-2018","total":"13174.33"},{"month":"Dec-2015","total":"0.00"}]

来源:https://stackoverflow.com/questions/55570335/showing-undefined-data-in-chart-js-but-showing-array-in-inspect-element

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!