这篇文章主要结合Struts2+json+Highcharts实现动态数据的显示。为了节省时间,就不写数据库了。在action中用一个集合来模拟从数据库取到的数据。模拟数据为三个学生在不同时间成绩的变化情况:

 
张三
李四
王五
第一周
90
86
95
第二周
95
98
91
第三周
80
64
76
第四周
85
75
90

注意本例中用到的数据为JSON数据。因此在action中声明返回json数据的变量并提供get/set方法。如:

1
2
// 返回学生信息的JSON数据
private String result;

模拟的数据和将数据集合转换成json格式的代码如下:

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
public String demo() {
        // 假如查询出来了三个学生信息
        dataList = new ArrayList();
        StudentScore stu1 = new StudentScore();
        StudentScore stu2 = new StudentScore();
        StudentScore stu3 = new StudentScore();
 
        stu1.setName("张三");
        List allgrade1 = new ArrayList();
        allgrade1.add(90);
        allgrade1.add(95);
        allgrade1.add(80);
        allgrade1.add(85);
        stu1.setData(allgrade1);
        dataList.add(stu1);
 
        stu2.setName("李四");
        List allgrade2 = new ArrayList();
        allgrade2.add(86);
        allgrade2.add(98);
        allgrade2.add(64);
        allgrade2.add(75);
        stu2.setData(allgrade2);
        dataList.add(stu2);
 
        stu3.setName("王五");
        List allgrade3 = new ArrayList();
        allgrade3.add(95);
        allgrade3.add(91);
        allgrade3.add(76);
        allgrade3.add(90);
        stu3.setData(allgrade3);
        dataList.add(stu3);
 
        try {
            result = JSONSerializer.toJSON(dataList).toString();
            System.out.println("json:" + result);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return "query_success";
    }
        返回的数据一定要是json格式的。如:

1
json:[{"data":[90,95,80,85],"name":"张三"},{"data":[86,98,64,75],"name":"李四"},{"data":[95,91,76,90],"name":"王五"}]
        struts.xml文件配置如下:

1
2
result
truefalsetext/html
        注意:result的type为json类型。
        js代码和以前的差不多,只是增加了一个ajax方法。如:

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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
$(function() {
    $.ajax({
        type : "POST",
        dataType : "JSON",
        url : "HighChartActionUrl_demo.action",
        success : function(result) {
            // 解析action中发过来的数据
            var userdata = eval('(' + result + ')');
            new Highcharts.Chart({
                chart : {
                    renderTo : 'gridTable1', // 放置图表的DIV容器对应的id属性
                    type : 'column' // 图表类型line, spline, area, areaspline,
                // column, bar, pie , scatter
                },
                title : {
                    text : '学生成绩' // 图表标题
                },
                subtitle : {
                    text : '10级3年2班' // 副标题
                },
                xAxis : {
                    categories : [ '第一周', '第二周', '第三周', '第四周', ]
                // x轴
                },
                credits : {
                    text : 'demo', // 设置LOGO区文字
                    href : 'http://www.javakfz.com' // 设置LOGO链接地址
                },
                exporting : {
                    enabled : true
                },
                yAxis : {
                    min : 0,
                    title : {
                        text : '成绩 (分)'
                    }
                },
                legend : {
                    layout : 'vertical',
                    backgroundColor : '#FFFFFF',
                    align : 'left',
                    verticalAlign : 'top',
                    x : 100,
                    y : 70,
                    floating : true,
                    shadow : true
                },
                tooltip : {
                                                 //当鼠标悬置数据点时的格式化提示
                    formatter : function() {
                        return '' + this.x + ': ' + this.y + '分';
                    }
                },
                plotOptions : {
                    column : {
                        dataLabels : {
                            enabled : true
                        },
                        pointPadding : 0.2,
                        borderWidth : 0
                    }
                },
                series : userdata
            });
        }
    });
});
 
        通过上面的代码,可以看出只有series发生了变化,前面的例子数据都是不变的,而这个例子的数据完全是动态显示的。Highcharts的使用还是比较简单的,例子只是用来入门的,还有很多高级特征就需要自己开发了。另外附上最终的效果图:

原创文章,转载请注明: 转载自java开发者

本文链接地址: highCharts+Struts2生成柱状图

highCharts+Struts2生成柱状图的更多相关文章

  1. HighCharts之2D柱状图

    1.HighCharts之2D柱状图源码 column.html: <!DOCTYPE html> <html> <head> <meta charset=& ...

  2. 如何用asp.net MVC框架、highChart库从sql server数据库获取数据动态生成柱状图

    如何用asp.net MVC框架.highChart库从sql server数据库获取数据动态生成柱状图?效果大概是这样的,如图: 请问大侠这个这么实现呢?

  3. html5生成柱状图(条形图)

    <html> <canvas id="a_canvas" width="1000" height="700">< ...

  4. HighCharts之2D柱状图、折线图的组合多轴图

    HighCharts之2D柱状图.折线图的组合多轴图 1.实例源码 SomeAxis.html: <!DOCTYPE html> <html> <head> < ...

  5. HighCharts之2D柱状图、折线图的组合双轴图

    HighCharts之2D柱状图.折线图的组合双轴图 1.实例源码 DoubleAxis.html: <!DOCTYPE html> <html> <head> & ...

  6. HighCharts之2D柱状图、折线图和饼图的组合图

    HighCharts之2D柱状图.折线图和饼图的组合图 1.实例源码 ColumnLinePie.html: <!DOCTYPE html> <html> <head&g ...

  7. 使用jfreechart生成柱状图、折线图、和饼状图

    JFreeChart是JAVA平台上的一个开放的图表绘制类库.它完全使用JAVA语言编写,是为applications, applets, servlets 以及JSP等使用所设计.下面我就详细介绍如 ...

  8. struts2生成随机验证码图片

    之前想做一个随机验证码的功能,自己也搜索了一下别人写的代码,然后自己重新用struts2实现了一下,现在将我自己实现代码贴出来!大家有什么意见都可以指出来! 首先是生成随机验证码图片的action: ...

  9. nodejs搭配phantomjs highcharts后台生成图表

    简单分享一下,后台使用nodejs结合highcharts.phantomjs生成报表图片的方法.这主要应用在日报邮件. 主要参考以下资料: http://www.highcharts.com/com ...

随机推荐

  1. Java实现二叉树及相关遍历方式

    Java实现二叉树及相关遍历方式 在计算机科学中.二叉树是每一个节点最多有两个子树的树结构.通常子树被称作"左子树"(left subtree)和"右子树"(r ...

  2. [LeetCode][Java] Substring with Concatenation of All Words

    题目: You are given a string, s, and a list of words, words, that are all of the same length. Find all ...

  3. linux最常用命令整理

    linux vim命令跳转到文档开头或末尾 gg:命令将光标移动到文档开头 G:命令将光标移动到文档末尾 <hr/> 网络 # ifconfig # 查看所有网络接口的属性 # iptab ...

  4. Win7如何修改文件夹的默认视图,如何把详细信息改为平铺视图

    先任意进入一个文件夹,右击选择平铺视图.   然后点击左上角的组织,文件夹和搜索选项,在文件夹选项的查看中点击"应用到文件夹",然后点击确定,弹出对话框,再确定.   随后再浏览别 ...

  5. SQL如何将EXCEL导入到SQL数据库

    1 新建一个EXCEL工作表,注意默认有三个工作簿,我们只在Sheet1中创建几个字段并存储若干值保存为TEST.xls 2运行Excel to MySQL软件,注意Sourece和Destinati ...

  6. .Net Framework 之 托管代码和非托管代码的区别

    一.什么是托管代码(managed code)? 托管代码:是微软的中间语言(IL),即微软中间语言MSIL(Microsoft Interspace Language). “ 源代码→机器码 ”运行 ...

  7. Android 事件分发

    引言 项目中涉及到的触摸事件分发较多,例如:歌词模式下,上下滑动滚动歌词,左右滑动切换歌曲.此时,理解事件分发机制显得尤为重要 , 既要保证下方的ViewPager能接收到,又要确保上层View能响应 ...

  8. Ubuntu下安装JDK7(附Clojure下载)

    转:http://www.linuxidc.com/Linux/2012-10/71557.htm 首先确实不得不说,网上有很多类似Ubuntu下安装JDK7的教程.不过大都是基于JDK6的bin文件 ...

  9. JS JSOP跨域请求实例详解

    JSONP(JSON with Padding)是JSON的一种“使用模式”,可用于解决主流浏览器的跨域数据访问的问题.这篇文章主要介绍了JS JSOP跨域请求实例详解的相关资料,需要的朋友可以参考下 ...

  10. Lintcode---单词的添加与查找

    设计一个包含下面两个操作的数据结构:addWord(word), search(word) addWord(word)会在数据结构中添加一个单词.而search(word)则支持普通的单词查询或是只包 ...