Estoy tratando de usar Angular-chart.js, no muestra nada para mí, aquí está mi página de JavaScript y HTML

(function(){
 angular.module("app", ["chart.js"]).controller("BarCtrl", function ($scope) {
    $scope.labels = ['2006', '2007', '2008', '2009', '2010', '2011', '2012'];
    $scope.series = ['Series A', 'Series B'];

    $scope.data = [
      [65, 59, 80, 81, 56, 55, 40],
      [28, 48, 40, 19, 86, 27, 90]
    ];
 });
})(); 
    
<!DOCTYPE html>
<html>

<head>
    <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.1.2/Chart.min.js
    "></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/angular.chartjs/latest/angular-chart.css
    " />
    <script src="angular-chart.min.js
    "></script>
    <script src="app.js"></script>
</head>

<body ng-app="app">
    <div ng-controller="BarCtrl">
        <canvas id="bar" class="chart chart-bar" chart-data="data" chart-labels="labels"></canvas>
    </div>

</body>

</html>

No entiendo dónde está el error, gracias de antemano por su ayuda

0
Belal Mostafa Amin 10 may. 2016 a las 18:44

4 respuestas

La mejor respuesta

Parece que angular-chart.js no es compatible con la versión 2 de Chart.js. A continuación hay un fragmento, que muestra un gráfico de trabajo. Incluye v1.1.1 de chart.js

angular.module("app", ["chart.js"]).controller("BarCtrl", function($scope) {
  $scope.labels = ['2006', '2007', '2008', '2009', '2010', '2011', '2012'];
  $scope.series = ['Series A', 'Series B'];

  $scope.data = [
    [65, 59, 80, 81, 56, 55, 40],
    [28, 48, 40, 19, 86, 27, 90]
  ];
});
<!DOCTYPE html>
<html>

<head>
  <script data-require="angularjs@1.5.3" data-semver="1.5.3" src="http://ajax.googleapis.com/ajax/libs/angularjs/1.5.3/angular.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/1.1.1/Chart.min.js"></script>
  <script src="http://jtblin.github.io/angular-chart.js/dist/angular-chart.js"></script>
  <link rel="stylesheet" href="https://raw.githubusercontent.com/jtblin/angular-chart.js/master/dist/angular-chart.min.css" />
  <script src="app.js"></script>
</head>

<body ng-app="app">
  <div ng-controller="BarCtrl">
    <canvas id="bar" class="chart chart-bar" chart-data="data" chart-labels="labels" chart-series="series"></canvas>
  </div>
</body>

</html>
3
Dustin Hodges 10 may. 2016 a las 16:43

En html data = "chart-data" sería chart-data = "data"

0
Syed Ekram Uddin 10 may. 2016 a las 16:06

Recibí este error al probar tu código:

(intermediate value)[e] is not a function angular chart

Parece que hay una versión que no coincide, intenté lo mismo con mi propio proyecto y obtuve el mismo error. Tome la V1.1.1 de Chart.js, como ya respondió @dustin.

Compruebe esto fiddle.

0
optimus 10 may. 2016 a las 19:17

Su enlace de datos es incorrecto

<canvas id="bar" class="chart chart-bar" data="chart-data" labels="chart-labels" ></canvas>

No tiene datos de gráficos variables ni etiquetas de gráficos en su controlador. Los nombraste de manera diferente.

De hecho, los atributos están en orden inverso. Debe ser chart-data = "data" chart-labels = "labels"

Ejemplo de http://jtblin.github.io/angular-chart.js/

<canvas id="bar" class="chart chart-bar" chart-data="data" chart-labels="labels" chart-series="series"></canvas>
0
yBrodsky 10 may. 2016 a las 16:04