詳解Chart.js輕量級(jí)圖表庫(kù)的使用經(jīng)驗(yàn)
前言
最近項(xiàng)目中遇到一個(gè)在頁(yè)面中畫(huà)圖表的需求,需要一個(gè)扇狀圖和一個(gè)柱狀圖,雖然能使用svg或canvas繪制,但吃力還不一定討好,所以研究接入了主流的第三方圖表庫(kù)供項(xiàng)目使用。下面主要記錄我使用過(guò)程中的一些體驗(yàn)和解決方法,具體教程請(qǐng)移步官方文檔。
技術(shù)選型
研究了Highcharts、百度的ECharts、阿里的G2和Charts.js四個(gè)圖表庫(kù),由于項(xiàng)目對(duì)圖表需求不大,圖表不復(fù)雜,所以引入了輕量級(jí)的Charts.js。Chart.js很容易上手,只需要在頁(yè)面中引用腳本文件,并創(chuàng)建 <canvas> 節(jié)點(diǎn)即可渲染出圖表。且為你的數(shù)據(jù)提供 8 種可視化展現(xiàn)方式,每種方式都具有動(dòng)態(tài)效果并且可定制;在所有現(xiàn)代瀏覽器(IE9+)上都有高效的繪圖效率;響應(yīng)式布局。
GitHub源碼: https://github.com/nnnick/Chart.js
Chart.js文檔:http://www.bootcss.com/p/chart.js/
引入
GitHUb上下載源碼,把里面的dist/Chart.bundle.js文件引入項(xiàng)目即可使用;查看源碼,發(fā)現(xiàn)其兼容了多種模塊加載方式,所以我使用requireJs在頁(yè)面中加載。
使用經(jīng)驗(yàn)
①圖表顏色值個(gè)數(shù)可以不與數(shù)據(jù)個(gè)數(shù)相等,如
var pieConfig = {
type: 'pie',
data: {
datasets: [{
data: [10, 20],
backgroundColor: ['#debd5a', '#ff6d4a', '#3cc9bf', '#7599e9',]
}]
}
}
②可以取消響應(yīng)式options: {responsive: false},方便控制圖表的大小,canvas多大圖表便多大,canvas不會(huì)自動(dòng)占滿(mǎn)外層容器。
③取消legend的點(diǎn)擊事件,因?yàn)辄c(diǎn)擊legend會(huì)默認(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'
}
}
效果如下

⑤柱狀圖去掉網(wǎng)格線,設(shè)置軸線顏色、矩形的寬度和y軸數(shù)據(jù)從0開(kāi)始展示。由于使用的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è)置軸文字字號(hào)和色值
fontSize: 12,
fontColor: '#666666'
}
}],
yAxes: [{
gridLines: {
color: 'rgba(0, 0, 0, 0)',// 隱藏要y軸軸線
zeroLineColor: '#666666'
},
ticks: {
fontSize: 12,
beginAtZero: true,// y軸數(shù)據(jù)從0開(kāi)始展示
fontColor: '#666666'
}
}]
}
}
效果如下

⑥給圖表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;
}
}
}
效果如下

tooltips: {
callbacks: {
label: function (tooptipItem) {
return tooptipItem.yLabel + '個(gè)' ;
}
}
}
效果如下

總結(jié)
語(yǔ)言功底有限,表達(dá)不到位敬請(qǐng)?jiān)?,本文主要作為自己?xiàng)目總結(jié)使用。以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 使用Chart.js圖表庫(kù)制作漂亮的響應(yīng)式表單
- Chart.js 輕量級(jí)HTML5圖表繪制工具庫(kù)(知識(shí)整理)
- 在 Angular 中使用Chart.js 和 ng2-charts的示例代碼
- 使用Vue.js 和Chart.js制作絢麗多彩的圖表
- ichart.js繪制虛線、平均分虛線效果的實(shí)現(xiàn)代碼
- Chart.js在Laravel項(xiàng)目中的應(yīng)用示例
- vue集成chart.js的實(shí)現(xiàn)方法
- 利用ECharts.js畫(huà)K線圖的方法示例
- JavaScript Chart 插件整理
- 詳解vue文件中使用echarts.js的兩種方式
- vue.js+Echarts開(kāi)發(fā)圖表放大縮小功能實(shí)例
- Chart.js功能與使用方法小結(jié)
相關(guān)文章
詳解javascript傳統(tǒng)方法實(shí)現(xiàn)異步校驗(yàn)
這篇文章主要為大家介紹了javascript實(shí)現(xiàn)異步校驗(yàn)的方法,感興趣的小伙伴們可以參考一下2016-01-01
8個(gè)鮮為人知但很實(shí)用的Web?API用法總結(jié)
在?Web?API?中,有非常有用的對(duì)象、屬性和函數(shù)可用于執(zhí)行小到訪問(wèn)?DOM?這樣的小任務(wù),大到處理音頻、視頻這樣的復(fù)雜任務(wù)。下面就帶大家一起來(lái)看看一些不常見(jiàn)但很實(shí)用的Web?API的用法2022-08-08
Javascript隨機(jī)標(biāo)簽云代碼實(shí)例
這篇文章主要分享一個(gè)Javascript隨機(jī)標(biāo)簽云代碼實(shí)例,需要的朋友可以參考下。2016-06-06
JavaScript輸出所選擇起始與結(jié)束日期的方法
這篇文章主要介紹了JavaScript輸出所選擇起始與結(jié)束日期的方法,涉及javascript結(jié)合HTML5元素操作日期運(yùn)算的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-07-07

