美文网首页
echarts的异步数据加载及更新

echarts的异步数据加载及更新

作者: John_Phil | 来源:发表于2019-06-11 16:58 被阅读0次

    echarts可以使用ajax实现异步刷新数据

    //后台代码

    package com.neuedu.servlet;
    
    import java.io.IOException;
    import java.util.ArrayList;
    import java.util.List;
    
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    import com.fasterxml.jackson.databind.ObjectMapper;
    
    /**
     * echarts3+java+ajax动态数据绑定形成图表
     * Servlet implementation class TestServlet
     */
    @WebServlet("/TestServlet")
    public class TestServlet extends HttpServlet {
        private static final long serialVersionUID = 1L;
           
        /**
         * @see HttpServlet#HttpServlet()
         */
        public TestServlet() {
            super();
            // TODO Auto-generated constructor stub
        }
    
        /**
         * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
         */
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // TODO Auto-generated method stub
            doPost(request, response);
        }
    
        /**
         * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
         */
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // TODO Auto-generated method stub
            
            List<Product> list = new ArrayList<Product>();
            
            //这里把“类别名称”和“销量”作为两个属性封装在一个Product类里,每个Product类的对象都可以看作是一个类别(X轴坐标值)与销量(Y轴坐标值)的集合
            list.add(new Product("衬衣", 10));
            list.add(new Product("短袖", 20));
            list.add(new Product("大衣", 30));
            
            ObjectMapper mapper = new ObjectMapper();    //提供java-json相互转换功能的类
            
            String json = mapper.writeValueAsString(list);    //将list中的对象转换为Json格式的数组
            
            System.out.println(json);
            
            //将json数据返回给客户端
            response.setContentType("text/html; charset=utf-8");
            response.getWriter().write(json);    
    
        }
    
    }
    
    

    前台代码

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    
        <title>ECharts Ajax </title>
        
        <!-- 引入 echarts.js -->
       <script src="../js/echarts.min.js"></script>
        <!-- 引入jquery.js -->
        <script src="../js/jquery.js"></script>
    </head>
    
    <body>
        <!-- 为ECharts准备一个具备大小(宽高)的Dom -->
        <div id="main" style="width: 600px;height:400px;"></div>
        
        <script type="text/javascript">
            
            var myChart = echarts.init(document.getElementById('main'));
             // 显示标题,图例和空的坐标轴
             myChart.setOption({
                 title: {
                     text: '异步数据加载示例'
                 },
                 tooltip: {},
                 legend: {
                     data:['销量']
                 },
                 xAxis: {
                     data: []
                 },
                 yAxis: {},
                 series: [{
                     name: '销量',
                     type: 'bar',
                     data: []
                 }]
             });
             
             myChart.showLoading();    //数据加载完之前先显示一段简单的loading动画
             
             var names=[];    //类别数组(实际用来盛放X轴坐标值)
             var nums=[];    //销量数组(实际用来盛放Y坐标值)
             
             $.ajax({
             type : "post",
             async : true,            //异步请求(同步请求将会锁住浏览器,用户其他操作必须等待请求完成才可以执行)
             url : "/echarts01/TestServlet",    //请求发送到TestServlet处
             data : {},
             dataType : "json",        //返回数据形式为json
             success : function(result) {
                 //请求成功时执行该函数内容,result即为服务器返回的json对象
                 if (result) {
                        for(var i=0;i<result.length;i++){       
                           names.push(result[i].name);    //挨个取出类别并填入类别数组
                         }
                        for(var i=0;i<result.length;i++){       
                            nums.push(result[i].num);    //挨个取出销量并填入销量数组
                          }
                        myChart.hideLoading();    //隐藏加载动画
                        myChart.setOption({        //加载数据图表
                            xAxis: {
                                data: names
                            },
                            series: [{
                                // 根据名字对应到相应的系列
                                name: '销量',
                                data: nums
                            }]
                        });
                        
                 }
             
            },
             error : function(errorMsg) {
                 //请求失败时执行该函数
             alert("图表请求数据失败!");
             myChart.hideLoading();
             }
        })
    
             
        </script>
        
    </body>
    </html> 
    
    后台日志
    访问结果

    相关文章

      网友评论

          本文标题:echarts的异步数据加载及更新

          本文链接:https://www.haomeiwen.com/subject/teoqfctx.html