chart.js를 사용하여 그래프를 작성해 보았습니다.

7634 단어 루비Rails슬림

Rails로 만든 앱에 그래프를 쉽게 넣는 방법



환경



루비 2.5.0p0
Rails 5.2.4.2
슬림

샘플 이미지



이런 그래프가 간단하게 완성됩니다.



절차



gem 설치
$ gem 'chart-js-rails', '~> 0.1.4'
bundle install

chart.js 설치

package.json
{
  "name": "hoge",
  "private": true,
  "dependencies": {
    "chart.js": "^2.7.1" ←★追記
  }
}
$ yarn install

//= require Chart.min 추가

hoge/app/assets/javascripts/application.js

// = require Chart.min
// = require rails-ujs
// = require activestorage
// = require turbolinks
// = require_tree .


view측

app/views/hoge/index.html.slim
<canvas id="myChart" width="400" height="400"></canvas>
javascript:
  draw_graph();

hoge/app/assets/javascripts/hoge.coffee

window.draw_graph = -> 
    ctx = document.getElementById("myChart").getContext('2d')
    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: {
                yAxes: [{
                    ticks: {
                        beginAtZero:true
                    }
                }]
            }
        }
    })

동작 확인
$ rails s

아래의 기사를 참고로 자신도 시험해 보았습니다만, 30분 정도로 곧바로 작성할 수 있었습니다. 앱에 그래프를 도입하고 싶은 분에게 추천합니다.

다음은 사용자가 쉽게 볼 수 있도록 사용자 정의합니다.

참고 기사

좋은 웹페이지 즐겨찾기