Chart.js轻量级图表库的使用经验

作者: 朱man | 来源:发表于2018-05-03 00:48 被阅读49次

前言

最近项目中遇到一个在页面中画图表的需求,需要一个扇状图和一个柱状图,虽然能使用svg或canvas绘制,但吃力还不一定讨好,所以研究接入了主流的第三方图表库供项目使用。下面主要记录我使用过程中的一些体验和解决方法,具体教程请移步官方文档。

技术选型

研究了Highcharts、百度的ECharts、阿里的G2Charts.js四个图表库,由于项目对图表需求不大,图表不复杂,所以引入了轻量级的Charts.js。Chart.js很容易上手,只需要在页面中引用脚本文件,并创建 <canvas> 节点即可渲染出图表。且为你的数据提供 8 种可视化展现方式,每种方式都具有动态效果并且可定制;在所有现代浏览器(IE9+)上都有高效的绘图效率;响应式布局。

引入

GitHUb上下载源码,把里面的dist/Chart.bundle.js文件引入项目即可使用;查看源码,发现其兼容了多种模块加载方式,所以我使用requireJs在页面中加载。

使用经验

  1. 图表颜色值个数可以不与数据个数相等,如
var pieConfig = {
      type: 'pie',
      data: {
          datasets: [{
            data: [10, 20],
            backgroundColor: ['#debd5a', '#ff6d4a', '#3cc9bf', '#7599e9',]
          }]
    }
}
  1. 可以取消响应式options: {responsive: false},方便控制图表的大小,canvas多大图表便多大,canvas不会自动占满外层容器。
  2. 取消legend的点击事件,因为点击legend会默认隐藏该数据的占比,所以我需要去掉点击事件,设置legend: {onClick: function () {}},修改点击事件。
  3. 把legend由默认的矩形修改成正方形,设置legend的字体大小和色值
options: {
    legend: {
      position: 'right',
      labels: {
        boxWidth: 14,// 修改宽度
        fontSize: 14,
        fontColor: '#666666'
      }
}
效果如下
  1. 柱状图去掉网格线,设置轴线颜色、矩形的宽度和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'
           }
      }]
   }
}
效果如下
  1. 给图表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 + '个' ;
     }
   }
}
效果如下

总结

语言功底有限,表达不到位敬请原谅,本文主要作为自己项目总结使用。

相关文章

  • Chart.js轻量级图表库的使用经验

    前言 最近项目中遇到一个在页面中画图表的需求,需要一个扇状图和一个柱状图,虽然能使用svg或canvas绘制,但吃...

  • Chart.js在Laravel项目中的应用

    本文为转载,原文:Chart.js在Laravel项目中的应用 介绍 Chart.js是一个HTML5图表库,使用...

  • Chart.js - 漂亮的 Javascript 图表开源库

    这是一个使用简单、动效现代酷炫js图表库,用来构建专业美观的数据图表。 介绍 Chart.js 是一个基于 can...

  • 前端常用图表库

    下面是挑选出的9个 JavaScript 图表库: Chart.js Chartist FlexChart Ech...

  • Chart.js 图表库

    提供很多图表样式 更多精彩 更多技术博客,请移步 IT人才终生实训与职业进阶平台 - 实训在线 官方地址 char...

  • 前端好网站

    小程序社区 css3 UI库 前端博客TX Chart.js | HTML5 图表绘制工具库 汇智网,学习最前沿...

  • rails中使用Chart.js制作图表

    一、简介 制作图表有很多的可以选择,如果想要实现的图表拥有的是比较直白的关系比较时,可以考虑使用chart.js,...

  • Chart.js 动态图表的使用

    一、相关资料 1. 简介 Chart.js 是一个基于 HTML5 的简单的面向对象的图表库,支持包括 IE7/8...

  • 前端框架——ECharts简介

    ECharts简介: ECharts是一个纯JavaScript图表库,底层依赖于轻量级的Canvas类库ZRen...

  • iOS - ORCharts

    ORCharts 一个可定制性较强,使用起来非常简单的 轻量级图表库。包括 环形图、饼状图、扇形图、折线图、曲线图...

网友评论

  • 嘿小美人:y轴设置成百分比,咋弄啊
    嘿小美人:@朱man 谢谢你,我是好久没登简书了,问题已解决。用的方法跟你的差不多
    朱man:主要使用这个属性值,ticks
    scales: {
    yAxes: [{
    ticks: {
    callback: function(value, index, labels) {
    return value+'%';
    }
    }
    }]
    },
    至于数据data,自己可以预先处理成百分比,如
    var pa = function (data) {
    return parseInt(data/28*100);
    };

    var barChartData = {
    labels: ["January", "February", "March", "April", "May", "June", "July"],
    datasets: [{
    data: [pa(1), pa(2), pa(3), pa(4), pa(5), pa(6), pa(7)]
    }]
    };
    这样就可以了,希望能帮到你。

本文标题:Chart.js轻量级图表库的使用经验

本文链接:https://www.haomeiwen.com/subject/xejhrftx.html