这是第一篇实例的步骤与代码。还有整个项目的结构图。
http://my.oschina.net/xshuai/blog/345117
原创的博文。转载注明出处。大家赶紧收藏吧。
本人highcharts新手。只是做个了练手的实例。还望大神指点。
上个图给大家看下效果。
点击 查看图表 如下图展示效果
-
Highcharts简介
Highcharts 是一个用纯JavaScript编写的一个图表库, 能够很简单便捷的在web网站或是web应用程序添加有交互性的图表,并且免费提供给个人学习、个人网站和非商业用途使用。HighCharts支持的图表类型有曲线图、区域图、柱状图、饼状图、散状点图和综合图表。
2.Highcharts 中文API 实例网站
http://www.hcharts.cn/index.php ---------------------中文官方网站
http://www.hcharts.cn/docs/index.php----------------中文教程
http://www.hcharts.cn/demo/index.php---------------在线演示
http://bbs.hcharts.cn/forum.php-----------------------中文论坛
3.下载highcharts 与使用
http://www.hcharts.cn/resource/index.php 使用最新的就可以了。
http://www.hcharts.cn/docs/index.php?doc=start-download 网站里面有详细的介绍每个文件夹的作用。
4.需要的文件 jquery 自己下载就好了
?
1
2
|
<
script
type
=
"text/javascript"
src
=
"${ctx}/js/jquery-1.10.2.js"
></
script
>
<
script
type
=
"text/javascript"
src
=
"${ctx}/js/highcharts/highcharts.js"
></
script
>
|
5.页面index.jsp增加的代码
?
1
2
3
4
5
6
7
8
9
10
|
html代码
<
a
href
=
"javascript:void(0);"
id
=
"highchart"
onclick
=
"gotoHighchart();"
class
=
"blank_btn"
>查看图表</
a
>
js代码
functiongotoHighchart(){
varurl='${ctx}/user/chartpage';
window.location.href=url;
}
操作当点击跳转页面
|
6.Controller代码
?
1
2
3
4
5
6
|
@RequestMapping
(value=
"chartpage"
)
public
Stringchartpage(HttpServletRequestrequest,
HttpServletResponseresponse){
return
"views/user/chartpage"
;
}
与第
5
步的想对应。
|
7.所需要的页面代码 chartpage.jsp
?
1
2
3
4
5
|
<
body
>
<
div
id
=
"container"
style
=
"width:800px;height:400px;margin:0auto"
></
div
>
</
body
>
|
以上实现了页面跳转的功能。需要图表的数据。还得继续
8.图表需要的数据方法
8.1 Controller
接受service传递json的字符串给页面
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
@RequestMapping
(value=
"/chart"
)
public
Stringchart(HttpServletRequestrequest,
HttpServletResponseresponse)
throws
Exception{
Stringresult=
null
;
try
{
result=userService.chart();
}
catch
(Exceptione){
if
(log.isErrorEnabled()){
log.error(
"查询列表失败"
,e);
}
result=
null
;
}
StringUtil.writeToWeb(result,
"html"
,response);
return
null
;
}
|
8.2 Service
将list对象存入map中。并转为json字符串数组
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
/**
*highcharts用的
*@Title:chart
*@Description:直接转出JSON传递给前台页面接受
*@return
*/
public
Stringchart(){
List<Map<String,Object>>list=userDao.chart();
Map<String,Object>map=
new
HashMap<String,Object>();
map.put(
"list"
,list);
Gsongson=
new
GsonBuilder().setDateFormat(
"yyyy-MM-dd"
).create();
Strings=gson.toJson(map);
return
s;
}
|
8.3 DAO
使用的的JDBCTemplate 传递sql语句查询。返回list对象
?
1
2
3
4
|
public
List<Map<String,Object>>chart(){
Stringsql=
"selectu.name,u.agefromuserinfou"
;
return
jdbcTemplate.queryForList(sql);
}
|
以上基本完成了数据的获取和转JSON字符串数组剩下就是在页面接受JSON并填充到highcharts图表里面
9.JS代码。使用AJAX传递过来。并填充到highcharts里面即可。最后一步,也是最要人命的一步。
一定要注意json字符串数组的解析。本人就是在这里纠结了半天多。怨自己没好好学习jquery。和强大的JSON字符串。
本人的json为 所以在遍历的时候需要注意一下自己的list这个数组里面的数据。可以忽略这句话。是本人的失误。
{"list":[{"name":"一号","age":19},{"name":"二号","age":22},{"name":"test","age":19}....]}
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
$(
function
(){
var
x=[];
var
y=[];
var
xtext=[];
var
color=[
"gray"
,
"pink"
,
"red"
,
"blue"
,
"yellow"
,
"green"
,
"#fff"
];
$.ajax({
type:
'get'
,
url:
'${ctx}/user/chart'
,
success:
function
(data){
var
json=eval(
"("
+data+
")"
);
var
s=1;
for
(
var
key
in
json.list){
json.list[key].y=json.list[key].age;
xtext=json.list[key].name;
json.list[key].color=color[key];
}
chart.series[0].setData(json.list);
},
error:
function
(e){
}
});
var
chart=
new
Highcharts.Chart({
chart:{
renderTo:
'container'
,
type:
'column'
},
title:{
text:
'年龄分布图'
},
xAxis:{
categories:xtext
},
yAxis:{
title:{
text:
'年龄'
},
},
series:[{
name:
"姓名"
}]
});
});
|
个人微博 http://weibo.com/zxshuai319
个人博客 http://my.oschina.net/xshuai/blog
公开QQ 783021975
个人联盟 http://www.bengbeng.com/?sid=687095 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|