原文链接:http://www.bootcss.com/p/chart.js/docs/

引入Chart.js文件

首先我们需要在页面中引入Chart.js文件。此工具库在全局命名空间中定义了Chart变量。

<script src="Chart.js"></script>

创建图表

为了创建图表,我们要实例化一个Chart对象。为了完成前面的步骤,首先需要需要传入一个绘制图表的2d context。以下是案例。

<canvas id="myChart" width="400" height="400"></canvas>
//Get the context of the canvas element we want to select
var ctx = document.getElementById("myChart").getContext("2d");
var myNewChart = new Chart(ctx).PolarArea(data);

我们还可以用jQuery获取canvas的context。首先从jQuery集合中获取我们需要的DOM节点,然后在这个DOM节点上调用 getContext("2d") 方法。

//Get context with jQuery - using jQuery's .get() method.
var ctx = $("#myChart").get(0).getContext("2d");
//This will get the first returned node in the jQuery collection.
var myNewChart = new Chart(ctx);

当我们完成了在指定的canvas上实例化Chart对象之后,Chart.js会自动针对retina屏幕做缩放。

Chart对象设置完成后,我们就可以继续创建Chart.js中提供的具体类型的图表了。下面这个案例中,我们将展示如何绘制一幅极地区域图(Polar area chart)。

new Chart(ctx).PolarArea(data,options);

We call a method of the name of the chart we want to create. We pass in the data for that chart type, and the options for that chart as parameters. Chart.js will merge the options you pass in with the default options for that chart type.

曲线图(Line chart)

简介

曲线图就是将数据标于曲线上的一种图表。

一般用于展示趋势数据,和比较两组数据集。

使用案例

new Chart(ctx).Line(data,options);

数据结构

var data = {
labels : ["January","February","March","April","May","June","July"],
datasets : [
{
fillColor : "rgba(220,220,220,0.5)",
strokeColor : "rgba(220,220,220,1)",
pointColor : "rgba(220,220,220,1)",
pointStrokeColor : "#fff",
data : [65,59,90,81,56,55,40]
},
{
fillColor : "rgba(151,187,205,0.5)",
strokeColor : "rgba(151,187,205,1)",
pointColor : "rgba(151,187,205,1)",
pointStrokeColor : "#fff",
data : [28,48,40,19,96,27,100]
}
]
}

The line chart requires an array of labels for each of the data points. This is show on the X axis.

The data for line charts is broken up into an array of datasets. Each dataset has a colour for the fill, a colour for the line and colours for the points and strokes of the points. These colours are strings just like CSS. You can use RGBA, RGB, HEX or HSL notation.

图表参数

Line.defaults = {

	//Boolean - If we show the scale above the chart data
scaleOverlay : false, //Boolean - If we want to override with a hard coded scale
scaleOverride : false, //** Required if scaleOverride is true **
//Number - The number of steps in a hard coded scale
scaleSteps : null,
//Number - The value jump in the hard coded scale
scaleStepWidth : null,
//Number - The scale starting value
scaleStartValue : null, //String - Colour of the scale line
scaleLineColor : "rgba(0,0,0,.1)", //Number - Pixel width of the scale line
scaleLineWidth : 1, //Boolean - Whether to show labels on the scale
scaleShowLabels : false, //Interpolated JS string - can access value
scaleLabel : "<%=value%>", //String - Scale label font declaration for the scale label
scaleFontFamily : "'Arial'", //Number - Scale label font size in pixels
scaleFontSize : 12, //String - Scale label font weight style
scaleFontStyle : "normal", //String - Scale label font colour
scaleFontColor : "#666", ///Boolean - Whether grid lines are shown across the chart
scaleShowGridLines : true, //String - Colour of the grid lines
scaleGridLineColor : "rgba(0,0,0,.05)", //Number - Width of the grid lines
scaleGridLineWidth : 1, //Boolean - Whether the line is curved between points
bezierCurve : true, //Boolean - Whether to show a dot for each point
pointDot : true, //Number - Radius of each point dot in pixels
pointDotRadius : 3, //Number - Pixel width of point dot stroke
pointDotStrokeWidth : 1, //Boolean - Whether to show a stroke for datasets
datasetStroke : true, //Number - Pixel width of dataset stroke
datasetStrokeWidth : 2, //Boolean - Whether to fill the dataset with a colour
datasetFill : true, //Boolean - Whether to animate the chart
animation : true, //Number - Number of animation steps
animationSteps : 60, //String - Animation easing effect
animationEasing : "easeOutQuart", //Function - Fires when the animation is complete
onAnimationComplete : null }

柱状图(Bar chart)

简介

A bar chart is a way of showing data as bars.

It is sometimes used to show trend data, and the comparison of multiple data sets side by side.

使用案例

new Chart(ctx).Bar(data,options);

数据结构

var data = {
labels : ["January","February","March","April","May","June","July"],
datasets : [
{
fillColor : "rgba(220,220,220,0.5)",
strokeColor : "rgba(220,220,220,1)",
data : [65,59,90,81,56,55,40]
},
{
fillColor : "rgba(151,187,205,0.5)",
strokeColor : "rgba(151,187,205,1)",
data : [28,48,40,19,96,27,100]
}
]
}

The bar chart has the a very similar data structure to the line chart, and has an array of datasets, each with colours and an array of data. Again, colours are in CSS format.

We have an array of labels too for display. In the example, we are showing the same data as the previous line chart example.

图表参数

Bar.defaults = {

	//Boolean - If we show the scale above the chart data
scaleOverlay : false, //Boolean - If we want to override with a hard coded scale
scaleOverride : false, //** Required if scaleOverride is true **
//Number - The number of steps in a hard coded scale
scaleSteps : null,
//Number - The value jump in the hard coded scale
scaleStepWidth : null,
//Number - The scale starting value
scaleStartValue : null, //String - Colour of the scale line
scaleLineColor : "rgba(0,0,0,.1)", //Number - Pixel width of the scale line
scaleLineWidth : 1, //Boolean - Whether to show labels on the scale
scaleShowLabels : false, //Interpolated JS string - can access value
scaleLabel : "<%=value%>", //String - Scale label font declaration for the scale label
scaleFontFamily : "'Arial'", //Number - Scale label font size in pixels
scaleFontSize : 12, //String - Scale label font weight style
scaleFontStyle : "normal", //String - Scale label font colour
scaleFontColor : "#666", ///Boolean - Whether grid lines are shown across the chart
scaleShowGridLines : true, //String - Colour of the grid lines
scaleGridLineColor : "rgba(0,0,0,.05)", //Number - Width of the grid lines
scaleGridLineWidth : 1, //Boolean - If there is a stroke on each bar
barShowStroke : true, //Number - Pixel width of the bar stroke
barStrokeWidth : 2, //Number - Spacing between each of the X value sets
barValueSpacing : 5, //Number - Spacing between data sets within X values
barDatasetSpacing : 1, //Boolean - Whether to animate the chart
animation : true, //Number - Number of animation steps
animationSteps : 60, //String - Animation easing effect
animationEasing : "easeOutQuart", //Function - Fires when the animation is complete
onAnimationComplete : null }

雷达图或蛛网图(Radar chart)

简介

A radar chart is a way of showing multiple data points and the variation between them.

They are often useful for comparing the points of two or more different data sets

使用案例

new Chart(ctx).Radar(data,options);

数据结构

var data = {
labels : ["Eating","Drinking","Sleeping","Designing","Coding","Partying","Running"],
datasets : [
{
fillColor : "rgba(220,220,220,0.5)",
strokeColor : "rgba(220,220,220,1)",
pointColor : "rgba(220,220,220,1)",
pointStrokeColor : "#fff",
data : [65,59,90,81,56,55,40]
},
{
fillColor : "rgba(151,187,205,0.5)",
strokeColor : "rgba(151,187,205,1)",
pointColor : "rgba(151,187,205,1)",
pointStrokeColor : "#fff",
data : [28,48,40,19,96,27,100]
}
]
}

For a radar chart, usually you will want to show a label on each point of the chart, so we include an array of strings that we show around each point in the chart. If you do not want this, you can either not include the array of labels, or choose to hide them in the chart options.

For the radar chart data, we have an array of datasets. Each of these is an object, with a fill colour, a stroke colour, a colour for the fill of each point, and a colour for the stroke of each point. We also have an array of data values.

图表

Radar.defaults = {

	//Boolean - If we show the scale above the chart data
scaleOverlay : false, //Boolean - If we want to override with a hard coded scale
scaleOverride : false, //** Required if scaleOverride is true **
//Number - The number of steps in a hard coded scale
scaleSteps : null,
//Number - The value jump in the hard coded scale
scaleStepWidth : null,
//Number - The centre starting value
scaleStartValue : null, //Boolean - Whether to show lines for each scale point
scaleShowLine : true, //String - Colour of the scale line
scaleLineColor : "rgba(0,0,0,.1)", //Number - Pixel width of the scale line
scaleLineWidth : 1, //Boolean - Whether to show labels on the scale
scaleShowLabels : false, //Interpolated JS string - can access value
scaleLabel : "<%=value%>", //String - Scale label font declaration for the scale label
scaleFontFamily : "'Arial'", //Number - Scale label font size in pixels
scaleFontSize : 12, //String - Scale label font weight style
scaleFontStyle : "normal", //String - Scale label font colour
scaleFontColor : "#666", //Boolean - Show a backdrop to the scale label
scaleShowLabelBackdrop : true, //String - The colour of the label backdrop
scaleBackdropColor : "rgba(255,255,255,0.75)", //Number - The backdrop padding above & below the label in pixels
scaleBackdropPaddingY : 2, //Number - The backdrop padding to the side of the label in pixels
scaleBackdropPaddingX : 2, //Boolean - Whether we show the angle lines out of the radar
angleShowLineOut : true, //String - Colour of the angle line
angleLineColor : "rgba(0,0,0,.1)", //Number - Pixel width of the angle line
angleLineWidth : 1, //String - Point label font declaration
pointLabelFontFamily : "'Arial'", //String - Point label font weight
pointLabelFontStyle : "normal", //Number - Point label font size in pixels
pointLabelFontSize : 12, //String - Point label font colour
pointLabelFontColor : "#666", //Boolean - Whether to show a dot for each point
pointDot : true, //Number - Radius of each point dot in pixels
pointDotRadius : 3, //Number - Pixel width of point dot stroke
pointDotStrokeWidth : 1, //Boolean - Whether to show a stroke for datasets
datasetStroke : true, //Number - Pixel width of dataset stroke
datasetStrokeWidth : 2, //Boolean - Whether to fill the dataset with a colour
datasetFill : true, //Boolean - Whether to animate the chart
animation : true, //Number - Number of animation steps
animationSteps : 60, //String - Animation easing effect
animationEasing : "easeOutQuart", //Function - Fires when the animation is complete
onAnimationComplete : null }

极地区域图(Polar area chart)

简介

Polar area charts are similar to pie charts, but each segment has the same angle - the radius of the segment differs depending on the value.

This type of chart is often useful when we want to show a comparison data similar to a pie chart, but also show a scale of values for context.

使用案例

new Chart(ctx).PolarArea(data,options);

数据结构

var data = [
{
value : 30,
color: "#D97041"
},
{
value : 90,
color: "#C7604C"
},
{
value : 24,
color: "#21323D"
},
{
value : 58,
color: "#9D9B7F"
},
{
value : 82,
color: "#7D4F6D"
},
{
value : 8,
color: "#584A5E"
}
]

As you can see, for the chart data you pass in an array of objects, with a value and a colour. The value attribute should be a number, while the color attribute should be a string. Similar to CSS, for this string you can use HEX notation, RGB, RGBA or HSL.

图表

These are the default chart options. By passing in an object with any of these attributes, Chart.js will merge these objects and the graph accordingly. Explanations of each option are commented in the code below.

PolarArea.defaults = {

	//Boolean - Whether we show the scale above or below the chart segments
scaleOverlay : true, //Boolean - If we want to override with a hard coded scale
scaleOverride : false, //** Required if scaleOverride is true **
//Number - The number of steps in a hard coded scale
scaleSteps : null,
//Number - The value jump in the hard coded scale
scaleStepWidth : null,
//Number - The centre starting value
scaleStartValue : null, //Boolean - Show line for each value in the scale
scaleShowLine : true, //String - The colour of the scale line
scaleLineColor : "rgba(0,0,0,.1)", //Number - The width of the line - in pixels
scaleLineWidth : 1, //Boolean - whether we should show text labels
scaleShowLabels : true, //Interpolated JS string - can access value
scaleLabel : "<%=value%>", //String - Scale label font declaration for the scale label
scaleFontFamily : "'Arial'", //Number - Scale label font size in pixels
scaleFontSize : 12, //String - Scale label font weight style
scaleFontStyle : "normal", //String - Scale label font colour
scaleFontColor : "#666", //Boolean - Show a backdrop to the scale label
scaleShowLabelBackdrop : true, //String - The colour of the label backdrop
scaleBackdropColor : "rgba(255,255,255,0.75)", //Number - The backdrop padding above & below the label in pixels
scaleBackdropPaddingY : 2, //Number - The backdrop padding to the side of the label in pixels
scaleBackdropPaddingX : 2, //Boolean - Stroke a line around each segment in the chart
segmentShowStroke : true, //String - The colour of the stroke on each segement.
segmentStrokeColor : "#fff", //Number - The width of the stroke value in pixels
segmentStrokeWidth : 2, //Boolean - Whether to animate the chart or not
animation : true, //Number - Amount of animation steps
animationSteps : 100, //String - Animation easing effect.
animationEasing : "easeOutBounce", //Boolean - Whether to animate the rotation of the chart
animateRotate : true, //Boolean - Whether to animate scaling the chart from the centre
animateScale : false, //Function - This will fire when the animation of the chart is complete.
onAnimationComplete : null
}

饼图(Pie chart)

简介

Pie charts are probably the most commonly used chart there are. They are divided into segments, the arc of each segment shows a the proportional value of each piece of data.

They are excellent at showing the relational proportions between data.

使用案例

new Chart(ctx).Pie(data,options);

数据结构

var data = [
{
value: 30,
color:"#F38630"
},
{
value : 50,
color : "#E0E4CC"
},
{
value : 100,
color : "#69D2E7"
}
]

For a pie chart, you must pass in an array of objects with a value and a color property. The value attribute should be a number, Chart.js will total all of the numbers and calculate the relative proportion of each. The color attribute should be a string. Similar to CSS, for this string you can use HEX notation, RGB, RGBA or HSL.

图表

These are the default options for the Pie chart. Pass in an object with any of these attributes to override them.

Pie.defaults = {
//Boolean - Whether we should show a stroke on each segment
segmentShowStroke : true, //String - The colour of each segment stroke
segmentStrokeColor : "#fff", //Number - The width of each segment stroke
segmentStrokeWidth : 2, //Boolean - Whether we should animate the chart
animation : true, //Number - Amount of animation steps
animationSteps : 100, //String - Animation easing effect
animationEasing : "easeOutBounce", //Boolean - Whether we animate the rotation of the Pie
animateRotate : true, //Boolean - Whether we animate scaling the Pie from the centre
animateScale : false, //Function - Will fire on animation completion.
onAnimationComplete : null
}

环形图(Doughnut chart)

简介

Doughnut charts are similar to pie charts, however they have the centre cut out, and are therefore shaped more like a doughnut than a pie!

They are aso excellent at showing the relational proportions between data.

使用案例

new Chart(ctx).Doughnut(data,options);

数据结构

var data = [
{
value: 30,
color:"#F7464A"
},
{
value : 50,
color : "#E2EAE9"
},
{
value : 100,
color : "#D4CCC5"
},
{
value : 40,
color : "#949FB1"
},
{
value : 120,
color : "#4D5360"
} ]

For a doughnut chart, you must pass in an array of objects with a value and a color property. The value attribute should be a number, Chart.js will total all of the numbers and calculate the relative proportion of each. The color attribute should be a string. Similar to CSS, for this string you can use HEX notation, RGB, RGBA or HSL.

图表

These are the default options for the doughnut chart. Pass in an object with any of these attributes to override them.

Doughnut.defaults = {
//Boolean - Whether we should show a stroke on each segment
segmentShowStroke : true, //String - The colour of each segment stroke
segmentStrokeColor : "#fff", //Number - The width of each segment stroke
segmentStrokeWidth : 2, //The percentage of the chart that we cut out of the middle.
percentageInnerCutout : 50, //Boolean - Whether we should animate the chart
animation : true, //Number - Amount of animation steps
animationSteps : 100, //String - Animation easing effect
animationEasing : "easeOutBounce", //Boolean - Whether we animate the rotation of the Doughnut
animateRotate : true, //Boolean - Whether we animate scaling the Doughnut from the centre
animateScale : false, //Function - Will fire on animation completion.
onAnimationComplete : null
}

Chart.js docs的更多相关文章

  1. JS组件系列——开源免费图表组件:Chart.js

    前言:最近被开源免费得有点上火了,各种组件首先想到的就是是开源否.是否免费.是否和bootstrap风格一致.想着以后做报表肯定要用到图表组件的,于是在Bootstrap中文网上面找到了Chart.j ...

  2. chart.js图表库案例赏析,饼图添加文字

    chart.js图表库案例赏析,饼图添加文字 Chart.js 是一个令人印象深刻的 JavaScript 图表库,建立在 HTML5 Canvas 基础上.目前,它支持6种图表类型(折线图,条形图, ...

  3. chart.js在html中画曲线图

    http://www.bootcss.com/p/chart.js/docs/ http://www.chartjs.org/docs/   中有详细讲解 一.简介 Chart.js是一个基于HTML ...

  4. vue.js 图表chart.js使用

    在使用这个chart.js之前,自己写过一个饼图,总之碰到的问题不少,所以能用现成的插件就用,能节省不少时间 这里不打算介绍chart.js里面详细的参数意义和各个参数的用法,只作为首次使用chart ...

  5. chart.js使用常见问题

    Chart.js是一个简单.面向对象.为设计者和开发者准备的图表绘制工具库. 在使用过程中新手可能会遇到很多问题导致图标无法显示.下面我们来看一下在使用过程中可能会遇到的问题. 刚开始用chart.j ...

  6. Chart.js 與 ASP.NET MVC 整合應用

    Chart.js 是一套開放原始碼的「圖表」繪製函式庫,和其他第三方的圖表工具相比,Chart.js 的特色如下: 支援 HTML 5.響應式網頁 (RWD, Responsive Web Desig ...

  7. Chart.js Y轴数据以百分比展示

    新手一枚,解决的问题喜欢记录,也许正好有人在网上迷茫的百度着.-0- 最近使用Chart.js做折线图的报表展示,直接显示整数啥的很好弄毕竟例子直接在哪里可以用,百分比就没办法了.百度慢慢汲取营养,虽 ...

  8. angulajs中引用chart.js做报表,修改线条样式

    目前还有个问题,在手机上看,当折线y轴值超过1000,会有点问题 1.下载chart js,可以用bower 命令下载 http://www.chartjs.org/docs/#line-chart- ...

  9. Chart.js & CPU 性能监控

    Chart.js 可视化动态 CPU 性能监控 https://github.com/gildata/RAIO/issues/337 https://github.com/chartjs/Chart. ...

随机推荐

  1. [Noip2004][Day ?][T?]合并果子(?.cpp)

    题目描述 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和.可 ...

  2. Java基础学习之数组基本属性和方法

    数组对于每一门编程语言都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同.Java语言中提供的数组是用来存储固定大小的同类型元素.你可以声明一个数组变量,如 int[100] 来代替直接 ...

  3. FTS5与DIY

    此文已由作者王荣涛授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. FTS5简介 前文已经介绍了FTS3/FTS4,本文着重介绍它们的继任者FTS5. FTS5是在SQLite ...

  4. Couchbase V(管理任务)

    Couchbase V(管理任务) 多读写 在Couchbase2.1中支持硬盘多读些(Multi- Readers and Writers),一般双核4G服务默认3个thread 4核16G内存一个 ...

  5. python多线程--线程同步

    如果多个线程共同对某个数据修改,则可能出现不可预料的结果,为了保证数据的正确性,需要对多个线程进行同步. 使用Thread对象的Lock和Rlock可以实现简单的线程同步,这两个对象都有acquire ...

  6. 最大数(cogs 1844)

    [题目描述] 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作.语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度. 2. 插入操作 ...

  7. 只有代码不会撒谎,如何通过Spring boot源码查看其对于各个框架的默认配置

    我发现很多开发对于看源码都有种恐惧心理,其实不必这样,大部分优秀的源码写的都挺直观的,很多时候,你在搜索引擎上搜到的一些东西并不一定是对的,但源码肯定造不了假,毕竟不管你怎么想,它就在那里,该是什么意 ...

  8. Android广播Broadcast

    Android Broadcast简单认识 Broadcast是应用程序间传输信息的一种机制,BroadcastReceiver是对发送出来的广播(Broadcast)进行过滤并接收相应的一类组件. ...

  9. php 基础复习 2018-06-19

    (1)date()函数 如果从代码返回的不是正确的时间,有可能是因为您的服务器位于其他国家或者被设置为不同时区. 因此,如果您需要基于具体位置的准确时间,您可以设置要用的时区. date_defaul ...

  10. DatePickerDialog

    package com.pingyijinren.helloworld.activity; import android.app.DatePickerDialog; import android.su ...