如何使用highcharts-ng和angularjs绘制多个highcharts

How to draw multiple highcharts using highcharts-ng and angularjs

本文关键字:highcharts 绘制 angularjs 何使用 highcharts-ng      更新时间:2023-09-26

我在我的应用程序中使用了highcharts-ng和angular js。对于一个简单的案例,我可以调用一个休息服务并能够使用它绘制图形。但是在我的场景中,使用相同的表单输入,我需要调用两个休息服务,并根据两个响应同时绘制两个图表(即第一个具有第一个响应的图形和具有另一个响应的第二个图形)。 我尝试了一些情况,但我只能绘制一个图形,如果我尝试绘制另一个图形,整个页面将重置。关于如何做到这一点的任何帮助。

这是我

解决您问题的方式。我没关系。

首先:在服务中创建绘制图

   angular.module('chartApp')
     .factory('drawChart', function () {
     return {
      lineChart: function (args) {
    // Draw charts
   var charts = [],
       chart;
    // agrs: this is variable mutable        
    var maps = args.maps,
        color = args.color,
        width = args.width,
        height = args.height,
        lablesY = args.lablesY,
        lablesX = args.lablesX,
        title = args.title;
    angular.forEach(maps, function (map) {
      chart = {            
        animation: true,
        options: {
          legend: {
            enabled: false   
          }
        },
        title: title,
        series: [{
          data: map,
          enableMouseTracking: false,
          color: color,
          marker: {
            enabled: false
          }
        }],
        loading: false,
        yAxis: {
          currentMin: 0,
          currentMax: 100,
          lineColor: '#cacaca',
          lineWidth: 1,
          gridLineWidth: null,
          labels: lablesY,
          title: null
        },   
        xAxis: {
          currentMin: 0,
          labels: lablesX,
          lineColor: '#cacaca',
          lineWidth: 1,
          tickWidth: 0
        },
        size: {
          width: width,
          height: height
        }
      };
      charts.push(chart);
    });
  return charts;
  }
  };
  });

第二次调用控制器

// Draw charts
var chartArgs = {
  maps: $scope.maps, 
  color: '#0ec679', 
  width: 245, 
  height: 125,
  lablesY: {
    enabled: false,
  },
  lablesX: {
    enabled: false,
  },
  title: {
    text: ''
  }
};
if (Object.keys($scope.maps).length != 0) {
  $scope.chartMaps = drawChart.lineChart(chartArgs);
}      

第三在视野中

<highchart config="chartMaps[$index]"></highchart>

这是我的解决方案:

Javascript:

// first chart
$scope.chartConfig1 = {
  chart: {
    type: 'bar'
  },
  title: {
    text: 'Fruit Consumption'
  }, ...
};
// second chart
$scope.chartConfig2 = {
  chart: {
    type: 'line'
  },
  title: {
    text: 'Fruit Consumption'
  }, ...
};

.HTML:

<!-- first chart -->
<div id="chartA">
  <highchart id="chart1" config="chartConfig1"></highchart>
</div>
<!-- second chart -->
<div id="chartB">
  <highchart id="chart2" config="chartConfig2"></highchart>
</div>

你可以无限期地重复这个范式