溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Chart.js輕量級圖表庫怎么用

發(fā)布時間:2021-07-27 14:01:01 來源:億速云 閱讀:136 作者:小新 欄目:web開發(fā)

小編給大家分享一下Chart.js輕量級圖表庫怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

技術(shù)選型

研究了Highcharts、百度的ECharts、阿里的G2和Charts.js四個圖表庫,由于項(xiàng)目對圖表需求不大,圖表不復(fù)雜,所以引入了輕量級的Charts.js。Chart.js很容易上手,只需要在頁面中引用腳本文件,并創(chuàng)建 <canvas> 節(jié)點(diǎn)即可渲染出圖表。且為你的數(shù)據(jù)提供 8 種可視化展現(xiàn)方式,每種方式都具有動態(tài)效果并且可定制;在所有現(xiàn)代瀏覽器(IE9+)上都有高效的繪圖效率;響應(yīng)式布局。

引入

GitHUb上下載源碼,把里面的dist/Chart.bundle.js文件引入項(xiàng)目即可使用;查看源碼,發(fā)現(xiàn)其兼容了多種模塊加載方式,所以我使用requireJs在頁面中加載。

使用經(jīng)驗(yàn)

①圖表顏色值個數(shù)可以不與數(shù)據(jù)個數(shù)相等,如

var pieConfig = {
   type: 'pie',
   data: {
     datasets: [{
      data: [10, 20],
      backgroundColor: ['#debd5a', '#ff6d4a', '#3cc9bf', '#7599e9',]
     }]
  }
}

②可以取消響應(yīng)式options: {responsive: false},方便控制圖表的大小,canvas多大圖表便多大,canvas不會自動占滿外層容器。

③取消legend的點(diǎn)擊事件,因?yàn)辄c(diǎn)擊legend會默認(rèn)隱藏該數(shù)據(jù)的占比,所以我需要去掉點(diǎn)擊事件,設(shè)置legend: {onClick: function () {}},修改點(diǎn)擊事件。

④把legend由默認(rèn)的矩形修改成正方形,設(shè)置legend的字體大小和色值

options: {
  legend: {
   position: 'right',
   labels: {
    boxWidth: 14,// 修改寬度
    fontSize: 14,
    fontColor: '#666666'
   }
}

效果如下

Chart.js輕量級圖表庫怎么用

⑤柱狀圖去掉網(wǎng)格線,設(shè)置軸線顏色、矩形的寬度和y軸數(shù)據(jù)從0開始展示。由于使用的Chart.js 2.0,配置參數(shù)變化很多,所以網(wǎng)上很多列子已失效,這里給出有效的配置代碼

options: {
  scales: {
   xAxes: [{
    gridLines: {
     color: 'rgba(0, 0, 0, 0)',// 隱藏x軸方向軸線
     zeroLineColor: '#666666'// 設(shè)置軸顏色
    },
    barPercentage: 0.2,// 設(shè)置柱寬度
    ticks: {// 設(shè)置軸文字字號和色值
     fontSize: 12,
     fontColor: '#666666'
    }
   }],
   yAxes: [{
    gridLines: {
     color: 'rgba(0, 0, 0, 0)',// 隱藏要y軸軸線
     zeroLineColor: '#666666'
     },
     ticks: {
      fontSize: 12,
      beginAtZero: true,// y軸數(shù)據(jù)從0開始展示
      fontColor: '#666666'
      }
   }]
  }
}

效果如下

Chart.js輕量級圖表庫怎么用

⑥給圖表tooltips的數(shù)據(jù)加上單位,可以使用tooltips的callback函數(shù)設(shè)置

tooltips: {
 callbacks: {
  label: function (tooltipItem, data) {
   var value = data.datasets[tooltipItem.datasetIndex].data[tooltipItem.index] + '%';
   var title = data.labels[tooltipItem.index] + ':';
   return title + value;
   }
  }
}

效果如下

Chart.js輕量級圖表庫怎么用

tooltips: {
  callbacks: {
   label: function (tooptipItem) {
    return tooptipItem.yLabel + '個' ;
   }
  }
}

效果如下

Chart.js輕量級圖表庫怎么用

以上是“Chart.js輕量級圖表庫怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI