準備
知識
HTML,JSの超基礎
CSSを知っているとグラフのデザイン設定がしやすいです。
CDNの追加
※CDNはファイルをインストールしないでもURLにアクセスするだけでchart.jsが使えるようになるよ〜ってやつです。
chart.jsのファイルをローカルにインストールしてそのパスを辿っても実装可能です。
こちらより最新のCDNを読み込むだけでOK!
一応コピペできるように載せておきます。
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.5.0/chart.min.js"></script>
実装
基本
JSでは以下の3つをを設定してあげればOK!
- グラフの指定(type)
- データの入力(data)
- 詳細設定(optioons)
<!-- ここにグラフが表示 -->
<canvas id="myChart"></canvas>
<script>
const type; //何グラフかの指定
let data; //データ
let options; //色々な設定
const ctx = document.getElementById("myChart").getContext("2d");//表示する場所取得
//ここで今までの設定した値を出力
const myChart = new Chart(ctx, {
type: type,
data: data,
options: options
});
<script>
基本的な折れ線グラフ
<canvas id="myChart"></canvas>
<script>
const type = "line";
let data = {
labels: [2010, 2011, 2012, 2013],
datasets: [{
label: "@taguchi",
data: [120, 300 , 100, 100]
}]
}
let options;
const ctx = document.getElementById("myChart").getContext("2d");
const myChart = new Chart(ctx, {
type: type,
data: data,
options: options
});
</script>
2つ以上のデータがある折れ線グラフ
<canvas id="myChart"></canvas>
<script>
const type = "line";
let data = {
labels: [2010, 2011, 2012, 2013],
datasets: [{
label: "@taguchi",
data: [120, 300, 100, 100]
}, {
label: '@fkoji',
data: [180, 250, 320, 180]
}]
}
let options;
const ctx = document.getElementById("myChart").getContext("2d");
const myChart = new Chart(ctx, {
type: type,
data: data,
options: options
});
</script>
optionsで縦軸をいじる
先ほどまでのoptionsに追加で値を入れます。
やりたいこと
- 最大最小値の設定
- 軸の刻みを100に設定
- 軸の数値の前に単位を設定
let options = {
scales: {
yAxes: [{
ticks: {
//この範囲より大きいデータが入ったらはみ出てしまう
// min: 0,
// max: 400,
suggestedMin: 0,
suggestedMax: 400,
stepSize: 100,
callback: function(value, index, values) {
//value: index番目の値
//index: 何番目か
//value: 全ての値
return 'JPY' + value;
}
}
}]
}
};
グラフのデザインを変更する
上の例で出しているtaguchiさんのグラフデザインを変えていきます.
- 線の色を赤色
- 線を5px
- 背景を青
- 直線に変更
- 点を三角に変更
全てデータにまつわるもので、グラフのデータごとにデザインを変えたいものなのでoptionではなくdataにスタイルを記述します。
let data = {
labels: [2010, 2011, 2012, 2013],
datasets: [{
label: "@taguchi",
data: [120, 300, 100, 100],
borderColor: 'red',
borderWidth: 5,
backgroundColor: 'rgba(0, 0, 255, 0.3)',
// fill: false,
//背景をなくしたい場合はfillをfalseに設定
lineTension: 0,
pointStyle: 'triangle'
}, {
label: '@fkoji',
data: [180, 350, 320, 180]
}]
};
棒グラフを作成
グラフのタイプを選択する際はtypeの修正ですね
const type = "bar";
//横棒グラフ
const type = 'horizontalBar';
積み上げグラフを作成
棒グラフかつ,全てに適応させたいので変更する箇所はoptionsですね
let options = {
scales: {
yAxes: [{
ticks: {
//この範囲より大きいデータが入ったらはみ出てしまう
// min: 0,
// max: 400,
suggestedMin: 0,
suggestedMax: 400,
stepSize: 100,
callback: function(value, index, values) {
//value: index番目の値
//index: 何番目か
//value: 全ての値
return 'JPY' + value;
}
},
stacked: true
}],
xAxes: [{
stacked: true
}],
}
};
混合グラフの作成
棒グラフと折れ線グラフの混合グラフを作っていきます。
今回は全体を棒グラフ、個別(fkoziさん)を折れ線グラフにします。
全体のタイプはいじることなく,fkojiさんのdataをいじってあげればできそうですね。
const type = "bar";
let data = {
labels: [2010, 2011, 2012, 2013],
datasets: [{
label: "@taguchi",
data: [120, 300, 100, 100],
borderColor: 'red',
borderWidth: 5,
backgroundColor: 'rgba(0, 0, 255, 0.3)',
lineTension: 0,
pointStyle: 'triangle'
}, {
label: '@fkoji',
data: [1800, 3500, 3200, 1800],
//この下2行を追加
type: "line",
fill: false
}]
};
ただ、このままだとグラフがかなり見にくくなってしまうので、棒グラフの縦軸と、折れ線グラフの縦軸の値を変えてあげた方が良さそうですね。
それぞれのdataの縦軸にIDを指定して実装しましょう。
const type = "bar";
let data = {
labels: [2010, 2011, 2012, 2013],
datasets: [{
label: "@taguchi",
data: [120, 300, 100, 100],
borderColor: 'red',
borderWidth: 5,
backgroundColor: 'rgba(0, 0, 255, 0.3)',
lineTension: 0,
pointStyle: 'triangle',
yAxisID: 'taguchi-axes'
}, {
label: '@fkoji',
data: [1800, 3500, 3200, 1800],
type: "line",
fill: false,
yAxisID: 'fkoji-axes'
}]
};
let options = {
scales: {
yAxes: [{
ticks: {
suggestedMin: 0,
suggestedMax: 400,
stepSize: 100,
callback: function(value, index, values) {
return 'JPY' + value;
}
},
id: 'taguchi-axes',
type: 'linear',
position: 'left'
},{
ticks: {
suggestedMin: 0,
suggestedMax: 2000
},
id: 'fkoji-axes',
type: 'linear',
position: 'right',
gridLines: {
display: false
}
}]
}
};
レーダーチャートの作成
基本は今までと同じです。
まずグラフのtypeを「radar」へ変更。
そして、縦軸と横軸という概念がなくなり1事件になるのでoptionsの書き方が楽になりますね!
表示するデータも少し変えるので今回は「type,data,options」の3セット書き換えます!
const type = "radar";
let data = {
labels: ['PHP', 'Ruby', 'Python', 'JavaScript', 'HTML'],
datasets: [{
label: '@taguchi',
data: [40, 50, 70, 30, 80],
backgroundColor: 'rgba(255, 0, 0, 0.3)'
}, {
label: '@fkoji',
data: [90, 62, 34, 80, 48],
backgroundColor: 'rgba(0, 0, 255, 0.3)'
}]
};
let options = {
scale: {
ticks: {
// suggestedMin: 0,
beginAtZero: true,
suggestedMax: 100
}
}
};
円グラフ
まずグラフのtypeを「pie」へ変更。
dataも少し変えてあげて
optionsはなにも指定しなくていいので1番楽ちん!
const type = "pie";
let data = {
labels: ['YES', 'NO', 'Maybe'],
datasets: [{
data: [122, 53, 33],
backgroundColor: ['tomato', 'skyblue', 'gray']
}]
};
let options = {};
ここまでで基礎は以上!
自分はドットインストールで基礎をざっと見ましたが、他にもドーナッツ型のグラフや細かい設定も講義にありました!
なのでより技術を高めたい人は見てみてもいいかもしれませんね!
今回ドキュメントにしたのは、今制作している販売管理システムでグラフの出力をしたいからです。
正解かは分かりませんが「サービスの肝となる技術は基礎をサラッと全体的に学んでその後必要な技術を付け足す。」
とういう作業を毎回やっています。
そこで、これ以降は現在開発中のサービスで必要な要素をピックアップしていくのでかなりニッチな内容になると思います。
結構細かい開発
x軸の値を任意の値の時のみ表示
たとえばx軸が1月〜12月の時軸の表示は2ヶ月に1回でいいんだよな〜って時ですね!
maxTicksLimitがポイント。
今回はlabelsが12個あるので6で割ってあげると2個ずつ出力されますね!
let data = {
labels: [0,1,2,3,4,5,6,7,8,9,10,11,12],
datasets: [{
fill: false,
label: "店舗A",
data: [120, 300, 100, 100, 100,100,100,100, 20, 30, 100, 20, 100],
borderColor: 'red'
}, {
fill: false,
label: '店舗B',
data: [180, 250, 320, 180, 10, 200, 200, 200, 200, 300, 100, 20, 100]
}]
}
let options = {
scales: {
yAxes: [{
ticks: {
suggestedMin: 0,
suggestedMax: 400,
stepSize: 100,
callback: function(value, index) {
return 'JPY' + value;
}
}
}],
xAxes: [{
ticks: {
maxTicksLimit: 6,
callback: function(value) {
return value + "月";
}
}
}]
}
};
個人的に表示させたい数になるように割った値を計算しないといけないってのが、しっくりこないので関数をうまく使ってあげて、軸に何個表示させる値を作るかを記入するだけでいいようにする
2回に1回軸を表示させるときはsetpに「2」と指定するだけで良くなりますね!
※ここはエンジニアの好みが分かれるところですね!
※自分の前職の現場はstepのような数を指定する定数は大文字という規則だったので正確にはCUT_STEP_NUMとかが変数名としては好まれるのかな??
//これを追加
const step = 2;
function tickCounts(data, step) {
return Math.round(data.labels.length / step);
}
//これに書き換える
maxTicksLimit: tickCounts(data, step),
コールバック関数使った方が綺麗にx軸のメモリを消せる
labelsの数が偶数このときは中央値がぴったり出てこないので、両端に値を出力すつことを考えるとうまく表示できないことを知ってしまいました。
そこで表示の制御をコールバック関数で管理します。
xAxes: [{
ticks: {
callback: function(value, index, values) {
if (index % 2 === 1) {
return "";
}
return value;
}
}
}]
そうすると綺麗に奇数の時のみ表示されていい感じになりました。
参考
・ドットインストール(https://dotinstall.com/lessons/basic_chartjs)