麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

詳解Chart.js輕量級圖表庫的使用經驗

2019-11-19 13:47:57
字體:
來源:轉載
供稿:網友

前言

最近項目中遇到一個在頁面中畫圖表的需求,需要一個扇狀圖和一個柱狀圖,雖然能使用svg或canvas繪制,但吃力還不一定討好,所以研究接入了主流的第三方圖表庫供項目使用。下面主要記錄我使用過程中的一些體驗和解決方法,具體教程請移步官方文檔。

技術選型

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

GitHub源碼: https://github.com/nnnick/Chart.js
Chart.js文檔:http://www.bootcss.com/p/chart.js/

引入

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

使用經驗

①圖表顏色值個數可以不與數據個數相等,如

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

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

③取消legend的點擊事件,因為點擊legend會默認隱藏該數據的占比,所以我需要去掉點擊事件,設置legend: {onClick: function () {}},修改點擊事件。

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

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

效果如下

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

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

效果如下

⑥給圖表tooltips的數據加上單位,可以使用tooltips的callback函數設置

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 + '個' ;   }  }}

效果如下

總結

語言功底有限,表達不到位敬請原諒,本文主要作為自己項目總結使用。以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美成人小视频 | 黄色片网站在线免费观看 | 欧美成人理论片乱 | 亚洲精品成人18久久久久 | 精品一区二区亚洲 | 免费久久久久 | 92看片淫黄大片欧美看国产片 | 午夜精品福利视频 | 亚洲网站在线播放 | 色婷婷久久久久久 | 免费一级毛片观看 | 99re久久最新地址获取 | 免费黄色入口 | 日韩精品中文字幕一区 | 国产精品欧美久久久久一区二区 | 爽毛片| 久草在线新视觉 | 成人偷拍片视频在线观看 | 亚洲乱码精品久久久久 | 国产毛片网站 | 久久久久久久久亚洲精品 | 成年人免费高清视频 | 国产手机国产手机在线 | 国产88久久久国产精品免费二区 | 操碰网 | 久久网站热最新地址 | 在线播放黄色片 | 1314av| 欧美成人精品一区二区三区 | 黑人三级毛片 | 久久久综合 | 亚洲第一页在线观看 | 最新中文字幕在线 | 久久久久久久午夜 | 欧美特级黄色 | 在线观看麻豆 | 国产日韩精品欧美一区视频 | 国产一区不卡 | av成人在线播放 | 精品国产一区二区三区在线观看 | 3344永久免费 |