自動化無しに生活無し

WEB開発関係を中心に備忘録をまとめています

【JavaScript】Chart.jsでグラフを描画する【棒グラフ、円グラフ、折れ線グラフ】

thumbnail

インストールとチュートリアル

最新版のCDNなら以下サイトから入手できる

https://www.jsdelivr.com/package/npm/chart.js?path=dist

とりあえず試したい場合は下記CDNをインストールする。(※一部仕様が現行バージョンと異なるため注意)

<script src="https://cdn.jsdelivr.net/npm/chart.js@3.6.2/dist/chart.min.js"></script>

続いて、グラフを表示させたい場所に下記、canvasタグを配置。

<canvas id="graph"></canvas>

これで準備完了。後は、次項以降のJavaScriptを発動させ、任意のグラフを描画させる。

棒グラフ

公式から拝借。

実行させるJavaScriptが下記。

const ctx = document.getElementById('graph').getContext('2d');
const myChart = new Chart(ctx, {
    type: 'bar',
    data: {
        labels: ['Red', 'Blue', 'Yellow', 'Green', 'Purple', 'Orange'],
        datasets: [{
            label: '# of Votes',
            data: [12, 19, 3, 5, 2, 3],
            backgroundColor: [
                'rgba(255, 99, 132, 0.2)',
                'rgba(54, 162, 235, 0.2)',
                'rgba(255, 206, 86, 0.2)',
                'rgba(75, 192, 192, 0.2)',
                'rgba(153, 102, 255, 0.2)',
                'rgba(255, 159, 64, 0.2)'
            ],
            borderColor: [
                'rgba(255, 99, 132, 1)',
                'rgba(54, 162, 235, 1)',
                'rgba(255, 206, 86, 1)',
                'rgba(75, 192, 192, 1)',
                'rgba(153, 102, 255, 1)',
                'rgba(255, 159, 64, 1)'
            ],
            borderWidth: 1
        }]
    },
    options: {
        scales: {
            y: {
                beginAtZero: true
            }
        }
    }
});

typebarを指定。必要な数だけdatalabelを追加、お好みでボーダーカラーや背景色、線の太さなどを設定する。

動かすとこうなる。

実際には、HTML側からデータを抜き取り、セットすることになるだろう。もしくはAjaxを発動させ、サーバーから直接データを受け取るか。

別の書き方

ちなみにこんなふうに記述することもできる。

const ctx = document.getElementById('graph').getContext('2d');

const labels = [1,2,3,4,5,6,7,];
const data = { 
  labels: labels,
  datasets: [{
    label: 'My First Dataset',
    data: [65, 59, 80, 81, 56, 55, 40],
    backgroundColor: [
      'rgba(255, 99, 132, 0.2)',
      'rgba(255, 159, 64, 0.2)',
      'rgba(255, 205, 86, 0.2)',
      'rgba(75, 192, 192, 0.2)',
      'rgba(54, 162, 235, 0.2)',
      'rgba(153, 102, 255, 0.2)',
      'rgba(201, 203, 207, 0.2)'
    ],  
    borderColor: [
      'rgb(255, 99, 132)',
      'rgb(255, 159, 64)',
      'rgb(255, 205, 86)',
      'rgb(75, 192, 192)',
      'rgb(54, 162, 235)',
      'rgb(153, 102, 255)',
      'rgb(201, 203, 207)'
    ],  
    borderWidth: 1
  }]  
};  
const config = { 
  type: 'bar',
  data: data,
  options: {
    scales: {
      y: {
        beginAtZero: true
      }   
    }   
  },  
};  

const myChart = new Chart(ctx, config);

動かすとこうなる。

内容は異なるが、同じように発動する。

円・ドーナツグラフ

円グラフにしたい場合、typepieにする。

const data = {
  labels: [
    'Red',
    'Blue',
    'Yellow'
  ],
  datasets: [{
    label: 'My First Dataset',
    data: [300, 50, 100],
    backgroundColor: [
      'rgb(255, 99, 132)',
      'rgb(54, 162, 235)',
      'rgb(255, 205, 86)'
    ],
    hoverOffset: 4
  }]
};
const config = {
  type: 'doughnut',
  data: data,
};

参照元:https://www.chartjs.org/docs/latest/charts/doughnut.html

折れ線グラフ

const labels = [1,2,3,4,5,6,7,];
const data = {
  labels: labels,
  datasets: [{
    label: 'My First Dataset',
    data: [65, 59, 80, 81, 56, 55, 40],
    fill: false,
    borderColor: 'rgb(75, 192, 192)',
    tension: 0.1
  }]
};
const config = {  
    type: 'line',  
    data: data,
};

const myChart = new Chart(ctx, config);

参照元:https://www.chartjs.org/docs/latest/charts/line.html

スポンサーリンク