成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

ECharts, PHP, MySQL, Ajax, JQuery實現前后端數據可視化

開發 數據可視化
最近要將后臺數據庫上的一些數據以可視化的方法顯示到前端,找來找去,發現百度開發的這套圖表工具庫還不錯,網上搜索了一下相關的教程,也算是實現了較為簡單的demo。于是寫下來,記錄一下。

[[206018]]

最近要將后臺數據庫上的一些數據以可視化的方法顯示到前端,找來找去,發現百度開發的這套圖表工具庫還不錯,網上搜索了一下相關的教程,也算是實現了較為簡單的demo。于是寫下來,記錄一下。

ECharts

ECharts是國人開發的一套前端的圖表工具庫,使用起來超方便,也很簡單(當然了,前提是理解了其工作原理之后)。

下面簡單的介紹一下,如何在項目中使用ECharts。

下載js代碼

下載地址: http://echarts.baidu.com/

個人覺得,開發人員下載完整版會比較好一點。而且官方建議的也是下載完整版。

 

下載Echarts

博主這里下載的是完整版,大約不到2M。

工作原理淺析

其實仔細的想想,ECharts的工作就是在網頁上顯示了一張特殊的圖片嘛。所以我們需要意識到,需要給“圖片”一個一個空間,這樣才會有圖表的安家之所嘛。

然后空間有了,也就是有地皮了。要蓋一個房子的話,必須得有框架不是。這樣的往上面添加些磚瓦水泥什么的才能將房子蓋起來。同樣的,ECharts也是這么個原理。但是這個“骨架”叫Option。至于這個option需要怎么設置,官網上有詳細的介紹,博主就不再這里重復的造輪子了。大家有興趣的可以到下圖展示的地方去學習。

 

ECharts3下載

在項目中引入ECharts

如題,本小節就是大致的講一下如何簡單的使用這個圖標庫。

不妨看一下下面的代碼:

 

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <meta charset="UTF-8"
  5. <title>入門</title> 
  6. <script src="../static/js/echarts.js"></script> 
  7. <script src="../static/js/sleeplib.js"></script> 
  8. </head> 
  9. <body> 
  10.  
  11.     <h1>開始測試</h1> 
  12.     <hr> 
  13.     <!-- 先準備一個用于盛放圖表的容器 --> 
  14.     
  15.         //通過 echarts.init 方法初始化一個 echarts 實例并通過 setOption 方法生成一個簡單的柱狀圖 
  16.  
  17.         //基于準備好的DOM,實例化echarts實例 
  18.         var myChart = echarts.init(document.getElementById("container")); 
  19.  
  20.         // 指定圖表的配置項和數據 
  21.         var option1 = { 
  22.             title : { 
  23.                 text : 'ECharts 入門案例' 
  24.             }, 
  25.             tooltip : { 
  26.                 text : '鼠標放上去之后的懸浮提示語句!' 
  27.             }, 
  28.             legend : { 
  29.                 data : [ '銷量' ] 
  30.             }, 
  31.             xAxis : { 
  32.                 data : [ '襯衫''羊毛衫''雪紡衫''褲子''高跟鞋''襪子''內褲' ] 
  33.             }, 
  34.             yAxis : {}, 
  35.             series : [ { 
  36.                 name : '銷量'
  37.                 type : 'bar'
  38.                 data : [ 7, 20, 36, 10, 10, 20, 28 ] 
  39.             } ] 
  40.         }; 
  41.  
  42.         // 使用上面的配置項作為參數,傳給echart來顯示 
  43.         myChart.setOption(option1); 
  44.     </script> 
  45. </body> 
  46. </html>  

關鍵在于***一句:

  1. myChart.setOption(option1); 

起作用不言而喻了吧。那么,得到的效果是什么呢? 如下圖:

 

Tutorial測試

另外手動的點擊上面的那個legend為“銷量”的小紅色的矩形,會有驚喜的喲。

<marquee><font color=”green” size=’6′>接下來開始進入今天的正題</font></marquee>

后臺處理

后臺處理包括使用PHP查詢數據庫,然后以數組的形式返回,再由JQuery以Ajax的形式獲取數據,交給前端進行顯示的過程。

數據庫端MySQL

數據是核心,所以建庫很重要。這里僅僅是為了演示,所以數據庫建的很簡單,如下圖:

 

建立數據庫

PHP端

需要注意的是,數據庫端返回的時候必須是JSON類型,這樣才可以被ajax處理的更方便。

  1. <?php 
  2. header("Content-type=text/json;charset=UTF-8"); 
  3.  
  4. $conn = mysql_connect("localhost""root""mysql"or die("連接數據庫的過程失敗!"); 
  5. mysql_query("set names utf-8"); 
  6. mysql_select_db("test"); 
  7.  
  8.  
  9. $resultset = mysql_query("select name, age  from echartsuser", $conn); 
  10. ////////////////////////////////////////////////準備數據進行裝填 
  11. $data = array(); 
  12. ////////////////////////////////////////////////實體類 
  13. class User
  14.     public $username; 
  15.     public $age; 
  16. ////////////////////////////////////////////////處理 
  17. while($row = mysql_fetch_array($resultset, MYSQL_ASSOC)) { 
  18.     $user = new User(); 
  19.     $user->username = $row['name']; 
  20.     $user->age = $row['age']; 
  21.     $data[] = $user
  22. $conn.close(); 
  23. // 返回JSON類型的數據 
  24. echo json_encode($data);  

那么驗證返回的數據類型到底是不是JSON,我們只需要做下接口測試即可。博主使用的是Chrome瀏覽器,裝了一個JSON的插件,所以可以很方便的檢測。如下圖:

 

JSON接口測試

JQuery & Ajax處理

JQuery真的是難的的一個函數工具庫,因此使用JQuery處理起來ajax請求會降低代碼編寫的復雜度,其底層將自動的處理兼容性問題。這很GEEK。

本例,目的很明確,獲取剛才的數據接口內的數據。所以代碼很簡單,如下:

  1. // 初始化兩個數組,盛裝從數據庫中獲取到的數據 
  2.     var names = [], ages = []; 
  3.      
  4.     //調用ajax來實現異步的加載數據 
  5.     function getusers() { 
  6.         $.ajax({ 
  7.             type: "post"
  8.             async: false
  9.             url: "../app/getuser.php"
  10.             data: {}, 
  11.             dataType: "json"
  12.             success: function(result){ 
  13.                 if(result){ 
  14.                     for(var i = 0 ; i < result.length; i++){ 
  15.                         names.push(result[i].username); 
  16.                         ages.push(result[i].age); 
  17.                     } 
  18.                 } 
  19.             }, 
  20.             error: function(errmsg) { 
  21.                 alert("Ajax獲取服務器數據出錯了!"+ errmsg); 
  22.             } 
  23.         }); 
  24.     return names, ages; 
  25.     } 
  26.      
  27.     // 執行異步請求 
  28.     getusers();  

ECharts 端處理

現在“萬事俱備,只欠東風”了,數據都已經有了,剩下的就是如何顯示它們了。按照一開始博主的蓋房子理論,下面就把骨架搭起來吧。

  1. // 初始化 圖表對象 
  2.         var mychart = echarts.init(document.getElementById("container")); 
  3.         // 進行相關項的設置,也就是所謂的搭搭骨架,方便待會的ajax異步的數據填充 
  4.         var option = { 
  5.             title : { 
  6.                 text : '姓名年齡分布圖' 
  7.             }, 
  8.             tooltip : { 
  9.                 show : true 
  10.             }, 
  11.             legend : { 
  12.                 data : [ 'age' ] 
  13.             }, 
  14.             xAxis : [ { 
  15.                 data : names 
  16.             } ], 
  17.             yAxis : [ { 
  18.                 type : 'value' 
  19.             } ], 
  20.             series : [ { 
  21.                 "name" : "age"
  22.                 "type" : "bar"
  23.                 "data" : ages 
  24.             } ] 
  25.         }; 
  26.  
  27.         // 將配置項賦給chart對象,來顯示相關的數據 
  28.         mychart.setOption(option);  

注意xAxis: 里面的names,和series里面的ages就是之前JQuery使用ajax方式獲取到的數據啦。

前端全部代碼

個人覺得有個完整的代碼會給人不少的啟發,那么這里還是貼出前端交互的代碼吧,也方便大家查看。

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <meta charset="UTF-8"
  5. <title>JQuery Ajax Test</title> 
  6. <script src="../static/js/echarts.js"></script> 
  7. <script src="../static/js/jquery-1.11.1.min.js"></script> 
  8. </head> 
  9. <body> 
  10.     <h1>PHP Ajax ECahrts 測試</h1> 
  11.     <hr> 
  12.  
  13.      
  14.     // 初始化兩個數組,盛裝從數據庫中獲取到的數據 
  15.     var names = [], ages = []; 
  16.      
  17.     //調用ajax來實現異步的加載數據 
  18.     function getusers() { 
  19.         $.ajax({ 
  20.             type: "post"
  21.             async: false
  22.             url: "../app/getuser.php"
  23.             data: {}, 
  24.             dataType: "json"
  25.             success: function(result){ 
  26.                 if(result){ 
  27.                     for(var i = 0 ; i < result.length; i++){ 
  28.                         names.push(result[i].username); 
  29.                         ages.push(result[i].age); 
  30.                     } 
  31.                 } 
  32.             }, 
  33.             error: function(errmsg) { 
  34.                 alert("Ajax獲取服務器數據出錯了!"+ errmsg); 
  35.             } 
  36.         }); 
  37.     return names, ages; 
  38.     } 
  39.      
  40.     // 執行異步請求 
  41.     getusers(); 
  42.      
  43.      
  44.     // 初始化 圖表對象 
  45.         var mychart = echarts.init(document.getElementById("container")); 
  46.         // 進行相關項的設置,也就是所謂的搭搭骨架,方便待會的ajax異步的數據填充 
  47.         var option = { 
  48.             title : { 
  49.                 text : '姓名年齡分布圖' 
  50.             }, 
  51.             tooltip : { 
  52.                 show : true 
  53.             }, 
  54.             legend : { 
  55.                 data : [ 'age' ] 
  56.             }, 
  57.             xAxis : [ { 
  58.                 data : names 
  59.             } ], 
  60.             yAxis : [ { 
  61.                 type : 'value' 
  62.             } ], 
  63.             series : [ { 
  64.                 "name" : "age"
  65.                 "type" : "bar"
  66.                 "data" : ages 
  67.             } ] 
  68.         }; 
  69.  
  70.         // 將配置項賦給chart對象,來顯示相關的數據 
  71.         mychart.setOption(option); 
  72.          
  73.          
  74.          
  75.          
  76.     </script> 
  77. <marquee>確認可以到達這里啊</marquee> 
  78.  
  79. </body> 
  80. </html>  

演示結果

至此,編碼任務就算完成了。那么迫不及待的來看看效果吧。

 

效果演示圖

那么,稍微的修改一下數據,再來看看結果會怎樣,刷新之后如下圖:

 

修改完數據

 

更新之后的數據

總結

***來回顧一下,本次試驗的收獲。其實也就是對于ECharts的一個比較“全棧”(請允許我用了這么個不太恰當的詞 O(∩_∩)O ) 。比較簡單的實現了后端以及前端的數據可視化顯示的一個流程。

用到的技術也都是很大眾化的了,當然后端不僅可以由PHP來完成,JAVA,Python,Golang等等都是可以的,只是使用PHP比較方便罷了。只要可以根據這個接口獲取到想要的數據就行。 

責任編輯:龐桂玉 來源: 36大數據
相關推薦

2020-03-01 14:01:22

Echarts數據可視化圖表

2017-10-14 13:54:26

數據可視化數據信息可視化

2019-12-18 14:40:09

數據可視化后端技術Python

2020-03-11 14:39:26

數據可視化地圖可視化地理信息

2014-05-28 15:23:55

Rave

2011-05-18 13:43:52

jQueryAjaxPHP

2023-04-17 07:32:41

2025-02-06 13:42:30

低代碼模塊化架構

2017-03-28 14:57:23

kylinsuperset可視化

2022-09-29 11:16:21

Python數據可視化

2015-08-20 10:00:45

可視化

2021-09-27 08:31:01

數據可視化柱狀圖折現圖

2020-07-06 14:50:36

地圖可視化Java

2009-04-21 14:26:41

可視化監控IT管理摩卡

2022-08-26 09:15:58

Python可視化plotly

2017-02-23 09:42:53

大數據數據可視化技術誤區

2023-05-08 16:29:34

2017-06-19 08:30:35

大數據數據可視化報表

2020-12-22 14:14:25

大數據數據可視化

2020-05-26 11:34:46

可視化WordCloud
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费国产视频 | 欧美精品在线一区二区三区 | 蜜桃黄网 | 日日操夜夜操天天操 | 午夜小视频在线播放 | 国产精品久久久久久久久久不蜜臀 | 欧美视频在线看 | 日朝毛片| 久久国内精品 | 欧美在线资源 | 97久久精品午夜一区二区 | 久久人体 | 成人水多啪啪片 | www.久久99 | 成人福利网 | 成人免费区一区二区三区 | 久久88 | 国内精品视频在线观看 | 日韩欧美中文字幕在线观看 | 亚洲综合久久久 | 精品一二 | 亚洲国产小视频 | 视频在线亚洲 | 9191在线播放 | 一区二区三区精品视频 | 亚洲视频一 | 日韩中文在线视频 | 国产一区二区电影网 | 二区久久 | 日韩综合在线 | 影音先锋中文在线 | 日本在线网站 | 日日日日日日bbbbb视频 | 日韩欧美亚洲 | 一级做a爰片久久毛片 | 免费黄色片在线观看 | 欧美一级片在线观看 | 久久高清免费视频 | 国产一区二区在线视频 | 五月婷婷中文 | www.99re |