Highcharts + jQuery + Servlet 实现从后台获取JSON实时刷新图表

效果图如下:


代码很详细,请详细阅读注释,HTML 代码如下:

    <!DOCTYPE HTML>  
    <html>  
          
        <head>  
            <meta http-equiv="Content-Type" content="text/html; charset=GBK">  
            <title> Highcharts + Ajax + Servlet Demo </title>  
            <script type="text/javascript" src="./jquery.min.js"></script>  
            <script type="text/javascript">  
                $(function() {  
                    $('#container').highcharts({  
                        chart: {  
                            type: 'spline',  
                            marginRight: 150,  
                            marginLeft: 150,  
                            marginBottom: 25,  
                            animation: Highcharts.svg,  
                              
                            events: {  
                                load: function() {  
      
                                    // 若有第3条线,则添加  
                                    // var series_other_property = this.series[2]  
                                    // 并在 series: [] 中添加相应的 (name, data) 对  
                                    var series_cpu = this.series[0];  
                                    var series_mem = this.series[1];  
      
                                    // 定时器,每隔1000ms刷新曲线一次  
                                    setInterval(function() {  
      
                                        // 使用JQuery从后台Servlet获取  
                                        // JSON格式的数据,  
                                        // 如 "{"cpu": 80,"mem": 10}"  
                                        jQuery.getJSON('./SomeServlet?action¶meter', null,  
                                        function(data) {  
      
                                            // 当前时间,为x轴数据  
                                            var x = (new Date()).getTime();  
      
                                            // y轴数据  
                                            var cpu = data.cpu;  
                                            var mem = data.mem;  
      
                                            // 更新曲线数据  
                                            series_cpu.addPoint([x, cpu], true, true);  
                                            series_mem.addPoint([x, mem], true, true);  
                                        });  
                                    },  
                                    1000/*启动间隔,单位ms*/  
                                    );  
                                }  
                            }  
                        },  
                        title: {  
                            text: '使用率(%)',  
                            x: -20  
                        },  
                        xAxis: {  
                            type: 'datetime',  
                            tickPixelInterval: 150  
                        },  
                        yAxis: {  
                            title: {  
                                text: '使用率(%)'  
                            },  
                            plotLines: [{  
                                value: 0,  
                                width: 1,  
                                color: '#808080'  
                            }]  
                        },  
                        tooltip: {  
                            valueSuffix: '%'  
                        },  
                        legend: {  
                            layout: 'vertical',  
                            align: 'right',  
                            verticalAlign: 'top',  
                            x: -10,  
                            y: 100,  
                            borderWidth: 0  
                        },  
                        series: [  
                        // 第1条曲线的(name, data)对  
                        {  
                            name: 'CPU',  
                            data: (function() {  
                                var data = [],  
                                time = (new Date()).getTime(),  
                                i;  
      
                                // 给曲线y值赋初值0  
                                for (i = -9; i <= 0; i++) {  
                                    data.push({  
                                        x: time + i * 1000,  
                                        cpu: 0  
                                    });  
                                }  
                                return data;  
                            })()  
                        },  
      
                        // 第2条曲线的(name, data)对  
                        {  
                            name: '内存',  
                            data: (function() {  
                                var data = [],  
                                time = (new Date()).getTime(),  
                                i;  
      
                                // 给曲线y值赋初值0  
                                for (i = -9; i <= 0; i++) {  
                                    data.push({  
                                        x: time + i * 1000,  
                                        y: 0  
                                    });  
                                }  
                                return data;  
                            })()  
                        },  
                        ]  
                    });  
                });  
            </script>  
            <style>  
                html,body { margin:0px; height:100%; }  
            </style>  
        </head>  
          
        <body>  
            <script src="./Highcharts/js/highcharts.js"></script>  
            <script src="./Highcharts/js/modules/exporting.js"></script>  
            <div id="container" style="min-width: 400px; height: 80%; margin: 0 auto">  
            </div>  
        </body>  
      
    </html>  



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在JavaScript中使用Highcharts实现3D饼图,你需要按照以下步骤进行配置和使用: 1. 首先,确保你已经引入了Highcharts库。你可以在HTML文件中通过使用`<script>`标签来引入Highcharts库的JavaScript文件。 2. 创建一个HTML容器来显示你的图表。在HTML文件中,你可以使用一个空的`<div>`元素,并为其指定一个唯一的ID,例如`<div id="chart-container"></div>`。这将是你的3D饼图的容器。 3. 在JavaScript文件中,你需要使用Highcharts的配置对象来定义你的3D饼图的设置。你可以通过创建一个名为`options`的对象来实现这一点。在`options`对象中,你可以指定图表的类型为`pie`,并设置`options.chart`属性为`{ type: 'pie', options3d: { enabled: true, alpha: 45, beta: 0 } }`以启用3D效果。 4. 在`options.series`属性中,你可以指定饼图的数据。每个数据点都是一个对象,包含`name`和`y`属性,分别表示数据点的名称和值。 5. 最后,你需要使用`Highcharts.chart`函数将图表绘制到指定的容器中。在JavaScript文件中,使用以下代码来创建和绘制3D饼图:`Highcharts.chart('chart-container', options);`。其中,`'chart-container'`是你在第2步中指定的容器的ID。 通过按照上述步骤进行配置和使用,你就能够在JavaScript中实现3D饼图的效果了。记得在绘制图表之前,确保你已经引入了Highcharts库,并正确配置了相关的设置和数据。<span class="em">1</span> #### 引用[.reference_title] - *1* [在Vue中使用highCharts绘制3d饼图的方法](https://download.csdn.net/download/weixin_38656609/13206251)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值