Title

基于highcharts+easui+java生成时趋图

前言:上一章以及详细介绍了highcharts的用法步骤以及官网教程,这里我就直接说生成时趋图的方法了。(不了解的可以去看我的上一篇文章)

一、效果展示

二,前台js代码

注明:每个人要展示的数据不一样我这里是以我的为例

官网demo以及代码

Highcharts.chart('container', {
    chart: {
        type: 'spline'
    },
    title: {
        text: 'Monthly Average Temperature'
    },
    subtitle: {
        text: 'Source: WorldClimate.com'
    },
    xAxis: {
        categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
            'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
    },
    yAxis: {
        title: {
            text: 'Temperature'
        },
        labels: {
            formatter: function () {
                return this.value + '°';
            }
        }
    },
    tooltip: {
        crosshairs: true,
        shared: true
    },
    plotOptions: {
        spline: {
            marker: {
                radius: 4,
                lineColor: '#666666',
                lineWidth: 1
            }
        }
    },
    series: [{
        name: 'Tokyo',
        marker: {
            symbol: 'square'
        },
        data: [7.0, 6.9, 9.5, 14.5, 18.2, 21.5, 25.2, {
            y: 26.5,
            marker: {
                symbol: 'url(https://www.highcharts.com/samples/graphics/sun.png)'
            }
        }, 23.3, 18.3, 13.9, 9.6]

    }, {
        name: 'London',
        marker: {
            symbol: 'diamond'
        },
        data: [{
            y: 3.9,
            marker: {
                symbol: 'url(https://www.highcharts.com/samples/graphics/snow.png)'
            }
        }, 4.2, 5.7, 8.5, 11.9, 15.2, 17.0, 16.6, 14.2, 10.3, 6.6, 4.8]
    }]
});

我的jsd其实对应的只需要改data就可以了

 

里面放空,然后用ajax请求来获得数据

下面是我的请求:(每个人需要的数据都不一样)

  function getJson(){
            var date=new Date;
            var year=date.getFullYear(); 
            var data1 = [];
            var i ;
            var params = {"nowYear":year};
            $.ajax({
                type : "POST", // 提交方式
                url : servicefulPath + '/irregularBagReportTotal/trendChart',
                data : params,
                success : function(result) {
                // 对json进行升序排序函数
                var json = result.data;
                for ( var key in json) {
                //通过遍历对象属性的方法,遍历键值对,获得key,然后通过 对象[key]获得对应的值
                var name = key;
                var value = json[key];
                console.log(value);
                if (json.hasOwnProperty(key)) {
                    data1.push([ json[key] ]);
                }
                }
                    chart1.series[0].setData(data1);
            }
        });
    }
      function getJsonSZX(){
            var date=new Date;
            var year=date.getFullYear(); 
            var data1 = [];
            var i ;
            var params = {"nowYear":year,"air3Code":"SZX"};
            $.ajax({
                type : "POST", // 提交方式
                url : servicefulPath + '/irregularBagReportTotal/trendChart',
                data : params,
                success : function(result) {
                // 对json进行升序排序函数
                var json = result.data;
                for ( var key in json) {
                //通过遍历对象属性的方法,遍历键值对,获得key,然后通过 对象[key]获得对应的值
                var name = key;
                var value = json[key];
                console.log(value);
                if (json.hasOwnProperty(key)) {
                    data1.push([ json[key] ]);
                }
                }
                    chart1.series[1].setData(data1);
            }
        });
    }
      

 三、后台代码

    public Map<String, Object> trendChart(int nowYear,String air3Code){
        Map<String, Object> map = new TreeMap<String, Object>();
        map = reportService.trendChart(nowYear,air3Code);
        return map;
    }

返回对应的map集合就可以了,是不是很简单。如果要实现动态刷新在js里面写一个定时器就可以了。

 

    //每隔10秒自动调用方法,实现图表的实时更新  
        window.setInterval(getJson,100000);   

最后欢迎大佬们前来评论交流探讨,学习快乐。

posted @ 2017-11-06 17:51  风尘小白  阅读(311)  评论(0编辑  收藏  举报