摘要
Highcharts图表控件是目前使用最为广泛的图表控件。本文将从零开始逐步为你介绍Highcharts图表控件。通过本文,你将学会如何配置Highcharts以及动态生成Highchart图表。
目录
- 前言(Preface)
- 安装(Installation)
- 如何设置参数(How to set up the options)
- 预处理参数(Preprocess the options)
- 活动图(Live charts)
一、前言(Preface)
Highcharts是一个非常流行,界面美观的纯Javascript图表库。它主要包括两个部分:Highcharts和Highstock。
Highcharts可以为您的网站或Web应用程序提供直观,互动式的图表。目前支持线,样条,面积,areaspline,柱形图,条形图,饼图和散点图类型。
Highstock可以为您方便地建立股票或一般的时间轴图表。它包括先进的导航选项,预设的日期范围,日期选择器,滚动和平移等等。
如果想要了解更多Highcharts的信息,可以参考官网:http://www.highcharts.com。
二、安装(Installation)
1.Highcharts沿用jQuery,MooTool以及Prototype等Javascript框架来处理基本的Javascript任务。因此,在使用Highcharts之前,需要在页面头部引用这些脚本文件。如果你使用jQuery作为基本框架,那么你需要在页面头部同时引用jQuery和Hightcharts两个文件。如下:
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js" type="text/javascript"></script> <script src="/js/highcharts.js" type="text/javascript"></script>
Highcharts(Highstock)已经内置了jQuery适配器(adapter)(注:可能是jQuery框架最流行的缘故),但是并没有内置MooTool等其他javascript框架的适配器(adapter)。因此,当我们使用MooTool等其他JS框架时,需要单独引用适配器(adapter)脚本文件。如下:
<script src="https://ajax.googleapis.com/ajax/libs/mootools/1.3.0/mootools-yui-compressed.js" type="text/javascript"></script> <script src="/js/adapters/mootools-adapter.js" type="text/javascript"></script> <script src="/js/highcharts.js" type="text/javascript"></script>
提示: 安装Highstock过程与上述相同,除了JavaScript文件名称是highstock.js而不是highcharts.js。
2.在您的网页头部的脚本标签,或在一个单独的js文件,添加JavaScript代码来初始化图表。renderTo参数用来设置图表渲染的位置,一般来说是一个具有ID的DIV元素(参考第3步)。
如果你想生成HighStock图表,有一个单独的构造方法调用Highcharts.StockChart。在这些图表中,数据源是一个典型的JavaScript数组数据。其来源可以是一个单独的JavaScript文件,或者是通过Ajax调用远程服务器提供的数据。
三、如何设置参数(How to set up the options)
- 在上面的例子中,Highcharts options被定义为对象字面值(object literals)。通过这种方法来标记配置,我们可以的到一个清晰的,可读性强的,占用空间低的配置对象。下面这种复杂的代码对于C程序员来说可能比较熟悉:
// 不良的风格 var options = new Object(); options.chart = new Object(); options.chart.renderTo = 'container'; options.chart.type = 'bar'; options.series = new Array(); options.series[0] = new Object(); options.series[0].name = 'Jane'; options.series[0].data = new Array(1, 0, 4);
// 良好的风格 var options = { chart: { renderTo: 'container', defaultSeriesType: 'bar' }, series: [{ name: 'Jane', data: [1, 0, 4] }] };
- 在创建命名的对象后,我们可以通过.操作符来扩展其成员。假设我们已经定义一个对象(见良好的风格代码)。下面代码代码将添加另一个series。请记住options.series是一个数组,因此我们可以使用push方法。
options.series.push({ name: 'John', data: [3, 4, 2] })
- 另外一个可以排上用场的事实是,对于JavsScript对象来说,点符号(.)和方括号[]是等价的。所以,你可以通过名称来访问成员。这意味着:
options.renderTo
options['renderTo']
4.1 案例学习: preprocessing the data from CSV
(1)创建一个外部的仅包含数据的CSV文件(数据源)。从下面数据文件中,我们可以看到第一行列出了类别的名称(类似于字段名)。后继的行的第一个位置列出了series name(比如:第二行的'John'),随后的位置列出相关的值(value)。在实际开发过程中,我们经常使用PHP或者其他服务器端编程语言(C#,java等)来创建这个文件的内容。或者你会选择其他的标记格式,比较的常见的如XML或者JSON(JSON相对XML更加轻巧)。在这些情况下,jQuery可以解析出数据对象本身。
Categories,Apples,Pears,Oranges,Bananas John,8,4,6,5 Jane,3,4,2,3 Joe,86,76,79,77 Janet,3,16,13,15
(2)定义基本的初始的参数。注意到,我们为categorys和series对象创建了空数组(empty arrays),稍后我们可以为其添加数据。
(3)加载数据。我们通过jQuery的.get方法来获取数据文件.csv的内容。在success回调函数中,我们解析请求返回的字符串,并将结果添加到参数对象(options object)的categories和series成员对象中,最后创建图表。请注意,我们不能在Ajax callback外创建图表,因为我们要等待服务器返回的数据(当请求成功后,返回数据,该过程是异步的)。
4.2 加载XML数据
从XML文件加载数据与加载CSV文件类似。Highcharts不能处理预定义的XML数据(只能处理数组)。因此,整个过程由你来编写XML数据,并为它定义一个解析函数。相对于CSV文件来说,XML的最大缺点是,它增加了一些标记数据(这也是选择JSON的缘故)。使用XML的好处在于,至少对于小量的数据来说,你不必要手动解析返回的数据。你可以使用jQuery现有的DOM解析能力来访问XML数。你可以在data-from-xml.htm看到实例,数据包含在data.xml。
五、活动图(Live Charts)
尽管我们已经通过配置对象(configuration object)定义图表,然后选择性地预处理(optionally preprocessed),最后通过new Highcharts.Chart()初始化和渲染图表,我们仍然有机会通过API来改变图表。chart,axis,series以及point对象有许多方法,比如update,remove,addSeries,addPoints等等。完整的列表可以查看API参考(the API Reference)下方法和属性。
5.1 案例学习:a live connection to the server
下面的例子将展示怎样构建一个活动的图表(live chart)通过每一秒种从服务器检索的数据。首先,我们要建立自定义函数requestData,它开始在图表加载事件(load event)中调用,随后在Ajax回调函数success中调用。你可以在live-server.htm中看到结果。
1.建立服务器。在这个例子中,我们选择PHP作为服务器脚本语言返回包含时间(time)以及y值(y value)的javascript数组。下列为live-server-data.php文件的代码:
2.定义全局变量。需要强调的是,这里必须定义chart全局变量,因为在document ready函数以及requestData函数均要访问。
var chart; // global
3.实现requestData函数。在这个例子中使用jQuery中$.ajax函数来处理ajax事务(你也可以用其他ajax框架来替代)。当数据从服务器成功返回后,通过addPoint方法添加点。
4.创建图表。
转载:http://liuhaorain.cnblogs.com
相关推荐
总之,Highcharts中文指南的发布,为国内开发者提供了一个系统学习和使用Highcharts的机会,使得制作各种交互式图表变得更为简单和直观。通过本指南,开发者可以掌握Highcharts的丰富功能,并将其应用于自己的Web...
**Highcharts使用指南** Highcharts是一款强大的JavaScript图表库,用于在Web页面上生成高质量的数据可视化图表。它提供了丰富的图表类型,包括折线图、柱状图、饼图、散点图等,并支持动态更新、交互操作以及...
`说明.htm`可能包含了关于如何使用Highcharts v9.3.3的指南,包括安装步骤、基本用法、API参考以及示例代码。`highcharts-9.3.3`文件夹则很可能包含了Highcharts库的所有源代码、CSS样式文件、JavaScript文件以及...
- 文档:可能包含API文档和使用指南,帮助开发者更好地理解和使用Highcharts。 通过学习和使用Highcharts-2.2.5源码,开发者不仅可以掌握如何在ASP.NET中创建动态图表,还能了解到Highcharts内部的工作机制,为更...
### 高级Highcharts学习指南:打造富丽堂皇、直观互动的JavaScript数据可视化 #### 核心知识点一:Highcharts概述与应用价值 Highcharts是一款功能强大的JavaScript图表库,专为网页和企业级开发需求设计,能创建...
- 文档更新:为开发者提供了更详尽的使用指南和示例。 要深入学习和使用Highcharts-4.0.3,你可以: 1. 阅读官方文档:了解所有可用的配置选项、方法和事件。 2. 查看示例:通过官方提供的示例代码,快速掌握如何...
总的来说,Highcharts 3.0.6是一个功能强大且易于使用的图表库,适合各种Web开发项目中的数据可视化需求。虽然现在已经有了更新的版本,但3.0.6仍然可以满足许多基本需求,并且由于其稳定性,仍被一些项目所采用。
5. **samples**或**examples**目录:包含了大量的示例代码,帮助开发者了解如何使用Highcharts。 6. **docs**或**documentation**目录:可能有详细的API文档和用户指南。 学习和使用Highcharts,你可以通过研究这些...
Highcharts是一款广泛应用于Web开发中的JavaScript图表库,它能够帮助开发者轻松创建各种动态、交互式的图表。在实际项目中,为了提高用户体验并满足离线...希望这个指南能帮助你成功实现自己的Highcharts导出服务器。
`readme.txt`是一个常见的说明文件,通常会提供项目的基本信息、安装指南、使用提示或开发者注意事项。它是快速了解项目的一个重要入口。 `graphics`和`gfx`目录可能存储了图表所需的图形资源,比如图标、背景图片...
在"index.htm"文件中,通常会有一个示例页面或者入门指南,展示了如何在HTML页面中引入Highcharts库并创建一个基本的图表。开发者可以通过查看和修改这个文件来学习如何使用Highcharts。 "js"文件夹内包含的是...
2. jqPlot的集成指南,特别是如何在Wicket应用中使用WiQuery来引入和配置这个插件。 3. 可能有关于WebRTC的代码或教程,说明如何在网页中启用和管理用户的话筒输入。 这些资源对于Web开发者,尤其是那些专注于数据...
这个压缩包包含了一系列与Highcharts相关的资源,方便开发者学习和使用。 1. **index.htm**:这个文件通常是网页的入口点,它可能包含了一个简单的示例或者高charts库的快速启动指南。通过这个文件,用户可以了解...
总的来说,Highcharts-4.1.7版本的开发文档和API为开发者提供了全面的指南,无论你是初学者还是经验丰富的开发者,都能从中找到所需的信息,实现复杂的数据可视化需求。在实际项目中,结合具体业务逻辑和设计需求,...
本文将详细解析使用 Django Highcharts 实现数据可视化的过程,并通过示例代码详细说明整个实现步骤。 在开始之前,需要了解几个关键点: 1. 开发环境配置:文中提到使用了 Python 2.7.14 版本和 Django 1.11.8 ...
通过这个参考指南,开发者可以了解如何初始化图表、设置数据、自定义样式以及交互功能等。例如,`chart`对象代表图表实例,`series`表示数据系列,`options`则包含了所有可配置的参数。 2. **ref.css 和 jquery.ui....
### 高级图表库Highcharts应用指南:2014年版详解 #### 知识点一:Highcharts概述 - **定义与功能**:Highcharts是一款基于JavaScript的图表库,用于创建动态、交互式的图表,广泛应用于Web开发项目中。它支持多种...
`readme.htm`通常包含项目的基本信息和使用指南,是了解项目的第一步。在这个文件中,你可能会看到如何引入Highcharts库,以及如何配置和初始化图表的示例代码。它会解释如何设置不同类型的图表,例如折线图(line ...