Echarts3.0版實現動態數據展示功能(通過ajax從伺服器端取數據)

来源:http://www.cnblogs.com/Dreamer-1/archive/2016/04/28/5444061.html
-Advertisement-
Play Games

Echarts(3.x版)官網實例的數據都是靜態的,實際使用中往往會要求從伺服器端取數據進行動態顯示,官網教程里給出的非同步數據載入很粗略,下麵就以官網最簡單的實例為例子,詳細演示如下過程:1.客戶端通過ajax發送請求;2.伺服器端Servlet接收請求;3.生成json數據並返回給客戶端;4.客戶 ...


Echarts(3.x版)官網實例的數據都是靜態的,實際使用中往往會要求從伺服器端取數據進行動態顯示,官網教程里給出的非同步數據載入很粗略,下麵就以官網最簡單的實例為例子,詳細演示如下過程:1.客戶端通過ajax發送請求;2.伺服器端Servlet接收請求;3.生成json數據並返回給客戶端;4.客戶端接收數據後顯示。

 

 

1.客戶端通過ajax發送請求

先繪製一個最簡單的Echarts圖表:

(這裡就直接貼上代碼了,直接用的是官網教程里非同步數據載入和更新里的代碼)

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>ECharts</title>
    
    <!-- 引入 echarts.js -->
    <script type="text/javascript" src="echarts.min.js"></script>
    <!-- 引入jquery.js -->
    <script type="text/javascript" src="jquery-1.12.3.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: []
             }]
         });


  </script> </body> </html>

看到了吧,現在option中的xAxis和yAxis里的data都是空值。待會兒我們會用從伺服器取回的數據去”填滿“它。

下麵貼上補充了ajax部分的完整前端代碼:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>ECharts</title>
    
    <!-- 引入 echarts.js -->
    <script type="text/javascript" src="echarts.min.js"></script>
    <!-- 引入jquery.js -->
    <script type="text/javascript" src="jquery-1.12.3.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 : "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>

 

2.伺服器端Servlet接收請求

客戶端的請求url是’TestServlet‘,那我們得先在web.xml配置以下映射:

    <servlet>
        <servlet-name>TestServlet</servlet-name>
        <servlet-class>test.TestServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>TestServlet</servlet-name>
        <url-pattern>/TestServlet</url-pattern>
    </servlet-mapping>

然後就來著手寫處理客戶端請求的TestServlet啦!

 

3.生成json數據並返回給客戶端

生成Json數據要用到額外的jar包,這裡我使用的jackson,json-lib 2010年就沒有再更新了…

簡單介紹一下jackson的用法:

①:先去http://mvnrepository.com/下載 jackson-core.jar,jackson-annotations.jar,jackson-databind.jar(都是2.x版本,jackson官網不知為何不提供服務了…這三個jar讓我一陣好找)

②:在項目的 Properties —> Build Path下引入這三個jar,註意還要在 Properties —> Deployment Assembly(Add —> Archives From File System)下引入這三個jar

然後就可以在TestServlet里使用jackson提供的工具類了。(關於jackson的詳細用法,這裡貼一下官網教程:http://wiki.fasterxml.com/JacksonInFiveMinutes

TestServlet代碼如下:

package test;

import java.io.IOException;
import java.util.*;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.fasterxml.jackson.databind.ObjectMapper;

public class TestServlet extends HttpServlet {

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req,resp);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    
        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);    
    }

TestServlet類中用到的自定義的Product類代碼如下:

package test;

public class Product {
    
    private String name;    //類別名稱
    private int num;        //銷量
    
    public Product(String name, int num) {
        this.name = name;
        this.num = num;
    }
    
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getNum() {
        return num;
    }
    public void setNum(int num) {
        this.num = num;
    }
    
    
}

 

4.客戶端接收數據後顯示

客戶端接受伺服器數據並解析後,就可以正常顯示圖表了:


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 關於字元串 問題描述:一般這類程式設計的題目較簡單,通過設計字元串的反轉,尋找子串,以及字元串的拼接、刪除操作等問題。 問題 實現一個演算法來判斷一個字元串中的字元是否唯一(即沒有重覆)? 設計演算法並寫出代碼移除字元串中重覆的字元(不能使用額外的緩存空間)? 寫一個函數判斷兩個字元串是否是變位詞? 思 ...
  • 我們知道,hibernate並沒有強制要求pojo(實體類 )屬性必須是基本數據類型或者是包裝類,但是我們把屬性聲明為基本數據類型( primitive types directly)或者包裝類 ( wrapping classes for primitives)對我們代碼的編寫有著深遠的影響。 1 ...
  • 問題:在分配管腳後總是出現下麵這個錯誤報告,編譯不過。 Error (171172):Detected confilicting assignments for the following nodes. Error (171173):Node mosi1_io from partition Top ...
  • 當我們需要開發一個方法用來查詢資料庫的時候,往往會遇到這樣一個問題:就是不知道用戶到底會輸入什麼條件,那麼怎麼樣處理sql語句才能讓我們開發的方法不管接受到什麼樣的條件都可以正常工作呢?這時where '1'='1'加上list就可以完美解決這個問題了,廢話少說,上代碼: **註解: 1,以上代碼操 ...
  • 前言 首先是要安裝JDK,JDK安裝好之後,還需要在電腦上配置"JAVA_HOME"、"path"、"classpath"這三個環境變數才能夠把java的開發環境搭建好。在沒安裝過jdk的環境下,path環境變數是系統變數,本來存在的,而JAVA_HOME和classpath是不存在的。 一、配置J ...
  • 函數是一種功能上的抽象,比如當我們寫一段程式,這個程式多次用到了發送郵件的功能(比如說:每天三點固定發送郵件,每當伺服器負載較重發送郵件提醒……),那麼我們就可以將發送郵件這個功能抽象出來,單獨對其定義一個函數進行實現。這樣在需要引用發送郵件功能的時候,我們就不需要重覆複製代碼,直接調用函數就可以了 ...
  • 註:文章原文為Dr. Charles Severance 的 《Python for Informatics》。文中代碼用3.4版改寫,併在本機測試通過。 一旦利用程式通過HTTP協議獲得並分析文檔變得簡單,那麼開發生成一個特殊設計的、供其他程式使用的文檔(不是在瀏覽器中顯示HTML)的方法也不用花 ...
  • Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorithm should run in linear time and in O(1) space. 代碼 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...