Chart.js轻量级图表库使用案例解析

这次给大家带来Chart.js轻量级图表库使用案例解析,Chart.js轻量级图表库使用的注意事项有哪些,下面就是实战案例,一起来看一下。

前言

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

技术选型

研究了Highcharts、百度的ECharts、阿里的G2和Charts.js四个图表库,由于项目对图表需求不大,图表不复杂,所以引入了轻量级的Charts.js。Chart.js很容易上手,只需要在页面中引用脚本文件,并创建 节点即可渲染出图表。且为你的数据提供 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'   }}

登录后复制

效果如下

Chart.js轻量级图表库使用案例解析

⑤柱状图去掉网格线,设置轴线颜色、矩形的宽度和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'      }   }]  }}

登录后复制

效果如下

Chart.js轻量级图表库使用案例解析

⑥给图表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;   }  }}

登录后复制

效果如下

Chart.js轻量级图表库使用案例解析

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

登录后复制

效果如下

Chart.js轻量级图表库使用案例解析

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

centos搭建ghost博客步骤分享

剖析Node.js cluster模块使用详解

以上就是Chart.js轻量级图表库使用案例解析的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2758400.html

(0)
上一篇 2025年3月8日 08:11:14
下一篇 2025年2月28日 00:43:52

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • nodejs express配置自签名https服务器步骤详解

    这次给大家带来nodejs express配置自签名https服务器步骤详解,nodejs express配置自签名https服务器的注意事项有哪些,下面就是实战案例,一起来看一下。 在nodejs中使用express来搭建框架可以说是非常…

    2025年3月8日 编程技术
    200
  • 通过构造AJAX参数实现表单元素JSON相互转换

    这篇文章主要介绍了通过构造ajax参数实现表单元素json相互转换 的相关介绍,需要的朋友可以参考下 ajax提交服务器数据, 整理一下转换方法。 HTML: 登录后复制 1.表单元素转QueryString var q = $(‘#fm,…

    编程技术 2025年3月8日
    200
  • SpringMVC环境下实现的Ajax异步请求JSON格式数据

    这篇文章主要介绍了springmvc环境下实现的ajax异步请求json格式数据的相关资料,需要的朋友可以参考下 一 环境搭建 首先是常规的spring mvc环境搭建,不用多说,需要注意的是,这里需要引入jackson相关jar包,然后在…

    2025年3月8日
    200
  • 浅析json与jsonp区别及通过ajax获得json数据后格式的转换

    一言以蔽之,json返回的是一串数据;而jsonp返回的是脚本代码(包含一个函数调用);接下来通过本文给大家介绍json与jsonp区别及通过ajax获得json数据后格式的转换,需要的朋友参考下  有关json与jsonp的区别(json…

    编程技术 2025年3月8日
    200
  • js原型使用详解

    这次给大家带来js原型使用详解,js原型使用的注意事项有哪些,下面就是实战案例,一起来看一下。 什么是原型? 在 javascript 中原形是一个对象,通过原形可以实现属性的继承。 let personBase = new Object(…

    2025年3月8日
    200
  • JS中常用到数组操作

    改变原始数组的操作方法: push:向数组末尾添加元素,并返回新的长度 pop:删除最后一个并返回删除的元素 unshift:向数组开头添加元素,并返回新的长度 shift:将第一个元素删除并且返回删除元素,空即为undefined rev…

    编程技术 2025年3月8日
    200
  • js的数组原型方法使用详解

    这次给大家带来js的数组原型方法使用详解,js的数组原型方法使用注意事项有哪些,下面就是实战案例,一起来看一下。 push会改变原数组的,返回值是改变后的数组长度 var arr = [1,2,3];var length = arr.pus…

    编程技术 2025年3月8日
    200
  • JS中使用接口步骤详解

    这次给大家带来JS中使用接口步骤详解,JS中使用接口的注意事项有哪些,下面就是实战案例,一起来看一下。 这篇是 js-interface 的 README,虽然并不是很复杂的一个东西,如果有人看的话我就写写源码思路了 ORZ 介绍 在做一个…

    编程技术 2025年3月8日
    200
  • JS中的JSON和Math使用案例分析

    这次给大家带来JS中的JSON和Math使用案例分析,JS中的JSON和Math使用的注意事项有哪些,下面就是实战案例,一起来看一下。 1.JSON JSON: 对象格式的字符串轻量的数据传输格式 登录后复制登录后复制 注意事项:  键名 …

    2025年3月8日
    200
  • 比较Ajax的三种实现及JSON解析

    本文给大家介绍ajax的三种实现及json解析的相关资料,对本文感兴趣的朋友参考下 本文主要是比较三种实现Ajax的方式,为以后的学习开个头。 准备: 1、  prototype.js2、  jquery1.3.2.min.js3、  js…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论