EChats+Ajax之柱狀圖的數據交互

 

一:下載 echarts.min.jsjavascript

 

選擇完整版進行下載,精簡版和經常使用版限制的某些功能html

 

 

二: echats入門案例java

一、引入 ECharts 和 JQueryjquery

[html] view plain copy
  1. <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>  
  2. <script src="./js/echarts.min.js"></script>  


二、準備一個具有高寬的 DOM 容器。web

[html] view plain copy
  1. <body>  
  2.   
  3.     <div id="main1" style="width: 900px; height: 350px;"></div>  
  4.     <div id="main2" style="width: 900px; height: 350px;"></div>  
  5.   
  6. </body>  

 

三、而後經過 echarts.init 方法初始化一個 echarts 實例並經過 setOption 方法生成一個簡單的柱狀圖,下面是完整代碼ajax

[html] view plain copy
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
  2.     pageEncoding="UTF-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  7. <title>Insert title here</title>  
  8. </head>  
  9. <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>  
  10. <script src="./js/echarts.min.js"></script>  
  11. <body>  
  12.   
  13.     <div id="main1" style="width: 900px; height: 350px;"></div>  
  14.     <div id="main2" style="width: 900px; height: 350px;"></div>  
  15.   
  16. </body>  
  17.   
  18. <script type="text/javascript">  
  19.     var zChart = echarts.init(document.getElementById("main1"));// 柱形圖模板一  
  20.   
  21.     var option = {  
  22.         color : [ '#3398DB' ],  
  23.         title : {  
  24.             text : 'ECharts 示例', //主標題文本,支持使用 \n 換行。  
  25.             link : '', //主標題文本超連接  
  26.             textStyle : { //該屬性用來定義主題文字的顏色、形狀等  
  27.                 color : '#3398DB',  
  28.             }  
  29.         },  
  30.         tooltip : {  
  31.             trigger : 'axis',  
  32.             axisPointer : { // 座標軸指示器,座標軸觸發有效  
  33.                 type : 'shadow' // 默認爲直線,可選爲:'line' | 'shadow'  
  34.             }  
  35.         },  
  36.         grid : {  
  37.             left : '6%',  
  38.             right : '20%',  
  39.             bottom : '20%',  
  40.             containLabel : true  
  41.         },  
  42.         xAxis : [ { //x軸列表展現  
  43.             type : 'category',  
  44.             data : [ '哈士奇', '鬥牛犬', '田園犬', '吉娃娃' ],  
  45.         } ],  
  46.         yAxis : [ { //定義y軸刻度  
  47.             type : 'value',  
  48.             scale : true,  
  49.             name : '月銷量',  
  50.             max : 140,  
  51.             min : 0,  
  52.             splitNumber : 20,  
  53.             boundaryGap : [ 0.2, 0.2 ]  
  54.         } ],  
  55.         series : [ {  
  56.             name : '銷量',  
  57.             type : 'bar', //bar 柱狀圖     line 折線圖 等  
  58.             barWidth : '40%', //柱的寬度  
  59.             data : [ '120', '30', '80', '65' ]  
  60.         } ]  
  61.     };  
  62.     zChart.setOption(option);  
  63.   
  64.     var xChart = echarts.init(document.getElementById('main2'));// 柱形圖模板二  
  65.   
  66.     var option1 = {  
  67.         title : {  
  68.             text : $("#signSet option:selected").val() == '' ? $(  
  69.                     "#signSet option:eq(1)").html() : $(  
  70.                     "#signSet option:selected").html(),  
  71.         },  
  72.         color : [ '#2474f6', '#006699', '#d84a38' ],  
  73.         tooltip : {  
  74.             trigger : 'axis',  
  75.             axisPointer : { // 座標軸指示器,座標軸觸發有效  
  76.                 type : 'shadow' // 默認爲直線,可選爲:'line' | 'shadow'  
  77.             }  
  78.         },  
  79.         legend : {  
  80.             data : [ '正常', '遲到', '未到' ]  
  81.         },  
  82.         grid : {  
  83.             left : '3%',  
  84.             right : '4%',  
  85.             bottom : '3%',  
  86.             containLabel : true  
  87.         },  
  88.         xAxis : [ {  
  89.             type : 'category',  
  90.             data : [ '一班', '二班', '三班', '四班' ]  
  91.         } ],  
  92.         yAxis : [ {  
  93.             type : 'value',  
  94.             scale : true,  
  95.             name : '月銷量',  
  96.             max : 60,  
  97.             min : 0,  
  98.             splitNumber : 20,  
  99.             boundaryGap : [ 0.2, 0.2 ]  
  100.         } ],  
  101.         series : [ {  
  102.             name : '正常',  
  103.             type : 'bar',  
  104.             data : [ '54', '49', '58', '56' ]  
  105.         },  
  106.   
  107.         {  
  108.             name : '遲到',  
  109.             type : 'bar',  
  110.             data : [ '5', '8', '4', '2' ]  
  111.         }, {  
  112.             name : '未到',  
  113.             type : 'bar',  
  114.             data : [ '3', '2', '1', '2' ],  
  115.   
  116.             markLine : {  
  117.                 lineStyle : {  
  118.                     normal : {  
  119.                         type : 'dashed'  
  120.                     }  
  121.                 },  
  122.                 data : [ [ {  
  123.                     type : 'min'  
  124.                 }, {  
  125.                     type : 'max'  
  126.                 } ] ]  
  127.             }  
  128.         }, ]  
  129.     }  
  130.     xChart.setOption(option1);  
  131. </script>  
  132. </html>  

 

 

四、效果圖spring

 

三:EChats + Ajax 完成數據交互數據庫

 

一、封裝EChats返回的結果集json

[html] view plain copy
  1. package com.debo.echats;  
  2.   
  3. import java.util.List;  
  4.   
  5. /**  
  6.  * 封裝echats須要的結果集  
  7. * @ClassName: EchatsRes   
  8. * @Description: TODO  
  9. * @author A18ccms a18ccms_gmail_com   
  10. * @date 2018年3月28日 上午9:38:54   
  11. *  
  12.  */  
  13. public class EchatsRes {  
  14.       
  15.     private List<String> xData;  
  16.     private List<Integer> yData;  
  17.     public List<String> getxData() {  
  18.         return xData;  
  19.     }  
  20.     public void setxData(List<String> xData) {  
  21.         this.xData = xData;  
  22.     }  
  23.     public List<Integer> getyData() {  
  24.         return yData;  
  25.     }  
  26.     public void setyData(List<Integer> yData) {  
  27.         this.yData = yData;  
  28.     }  
  29.     @Override  
  30.     public String toString() {  
  31.         return "EchatsRes [xData=" + xData + ", yData=" + yData + "]";  
  32.     }  
  33. }  


二、Controller層,模擬數據app

[html] view plain copy
  1. package com.debo.echats;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5.   
  6. import org.springframework.stereotype.Controller;  
  7. import org.springframework.web.bind.annotation.RequestMapping;  
  8. import org.springframework.web.bind.annotation.RequestMethod;  
  9. import org.springframework.web.bind.annotation.ResponseBody;  
  10.   
  11. @Controller  
  12. @RequestMapping("/echats")  
  13. public class Echats {  
  14.   
  15.       
  16.     @ResponseBody //返回json格式數據  
  17.     @RequestMapping(method = RequestMethod.GET)  
  18.     public EchatsRes echats() {  
  19.           
  20.         //爲了簡單,這裏省略從數據庫查詢數據,選擇直接模擬  
  21.         List<String> xList = new ArrayList<String>();  
  22.         List<Integer> yList = new ArrayList<Integer>();  
  23.   
  24.         xList.add("哈士奇");  
  25.         xList.add("鬥牛犬");  
  26.         xList.add("田園犬");  
  27.         xList.add("吉娃娃");  
  28.   
  29.         yList.add(120);  
  30.         yList.add(30);  
  31.         yList.add(80);  
  32.         yList.add(55);  
  33.   
  34.         EchatsRes echatsRes = new EchatsRes();  
  35.         echatsRes.setxData(xList);  
  36.         echatsRes.setyData(yList);  
  37.   
  38.         return echatsRes;  
  39.     }  
  40.   
  41. }  

注意:@responseBody註解須要jackson依賴

[html] view plain copy
  1. <dependency>  
  2.     <groupId>com.fasterxml.jackson.core</groupId>  
  3.     <artifactId>jackson-core</artifactId>  
  4.     <version>2.4.3</version>  
  5. </dependency>  
  6. <dependency>  
  7.     <groupId>com.fasterxml.jackson.core</groupId>  
  8.     <artifactId>jackson-databind</artifactId>  
  9.     <version>2.4.3</version>  
  10. </dependency>  

 

三、jsp完整代碼

[html] view plain copy
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
  2.     pageEncoding="UTF-8"%>  
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  4. <html>  
  5. <head>  
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
  7. <title>EChats和Ajax數據交互</title>  
  8.   
  9. <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>  
  10. <script src="./js/echarts.min.js"></script>  
  11. </head>  
  12. <body>  
  13.   
  14.     <div><input type="button" id="show" value="點擊顯示圖表"></div>  
  15.     <!-- 柱狀圖 -->  
  16.     <div id="main" style="width: 900px; height: 350px;"></div>  
  17.   
  18. </body>  
  19.   
  20. <script type="text/javascript">  
  21.       
  22.     var zChart = echarts.init(document.getElementById("main"));// 柱形圖模板  
  23.       
  24.     $("#show").on("click", function() {  
  25.         $.ajax({  
  26.             url : "/demo/echats.do",  
  27.             type : 'GET',  
  28.             success : function(data) {  
  29.                 fun(data.xData, data.yData);  
  30.             },  
  31.             error : function(data){  
  32.                 alert(1);  
  33.             }  
  34.         });  
  35.     })  
  36.   
  37.     function fun(x_data, y_data) {  
  38.   
  39.         var option = {  
  40.             color : [ '#3398DB' ],  
  41.             title : {  
  42.                 text : 'ECharts 示例', //主標題文本,支持使用 \n 換行。  
  43.                 link : '', //主標題文本超連接  
  44.                 textStyle : { //該屬性用來定義主題文字的顏色、形狀等  
  45.                     color : '#3398DB',  
  46.                 }  
  47.             },  
  48.             tooltip : {  
  49.                 trigger : 'axis',  
  50.                 axisPointer : { // 座標軸指示器,座標軸觸發有效  
  51.                     type : 'shadow' // 默認爲直線,可選爲:'line' | 'shadow'  
  52.                 }  
  53.             },  
  54.             grid : {  
  55.                 left : '6%',  
  56.                 right : '20%',  
  57.                 bottom : '20%',  
  58.                 containLabel : true  
  59.             },  
  60.             xAxis : [ { //x軸列表展現  
  61.                 type : 'category',  
  62.                 data : x_data,  
  63.             } ],  
  64.             yAxis : [ { //定義y軸刻度  
  65.                 type : 'value',  
  66.                 scale : true,  
  67.                 name : '月銷量',  
  68.                 max : 140,  
  69.                 min : 0,  
  70.                 splitNumber : 20,  
  71.                 boundaryGap : [ 0.2, 0.2 ]  
  72.             } ],  
  73.             series : [ {  
  74.                 name : '銷量',  
  75.                 type : 'bar', //bar 柱狀圖     line 折線圖 等  
  76.                 barWidth : '40%', //柱的寬度  
  77.                 data : y_data  
  78.             } ]  
  79.         };  
  80.   
  81.         zChart.setOption(option);  
  82.     }  
  83.       
  84. </script>  
  85. </html>  

 

四、效果圖

 

 

 

 

 

 

 

 

原文做者:祈澈姑娘

相關文章
相關標籤/搜索