精准猎取科技资讯,天堂视频在线观看,高效阅读科技新闻_黄色av网站在线免费观看_科技猎

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

我是創始人李巖:很抱歉!給自己產品做個廣告,點擊進來看看。  

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

作者:菩提樹下的煮茶小童子

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

ECharts

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

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

下載js代碼

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

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

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

下載Echarts

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

工作原理淺析

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

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

ECharts, PHP, MySQL, Ajax, JQuery 實現前后端數據可視化-36大數據
ECharts3下載

在項目中引入ECharts

如題,本小節就是大致的講一下如何簡單的使用這個圖標庫。
不妨看一下下面的代碼:

				<!DOCTYPE html>
				<html>
				<head>
				<meta charset="UTF-8">
				<title>入門</title>
				<script src="../static/js/echarts.js"></script>
				<script src="../static/js/sleeplib.js"></script>
				</head>
				<body>
				<h1>開始測試</h1>
				<hr>
				<!-- 先準備一個用于盛放圖表的容器 -->
				//通過 echarts.init 方法初始化一個 echarts 實例并通過 setOption 方法生成一個簡單的柱狀圖
				//基于準備好的DOM,實例化echarts實例
				var myChart = echarts.init(document.getElementById("container"));
				// 指定圖表的配置項和數據
				var option1 = {
				title : {
				text : 'ECharts 入門案例'
				},
				tooltip : {
				text : '鼠標放上去之后的懸浮提示語句!'
				},
				legend : {
				data : [ '銷量' ]
				},
				xAxis : {
				data : [ '襯衫', '羊毛衫', '雪紡衫', '褲子', '高跟鞋', '襪子', '內褲' ]
				},
				yAxis : {},
				series : [ {
				name : '銷量',
				type : 'bar',
				data : [ 7, 20, 36, 10, 10, 20, 28 ]
				} ]
				};
				// 使用上面的配置項作為參數,傳給echart來顯示
				myChart.setOption(option1);
				</script>
				</body>
				</html>
			

關鍵在于最后一句:

myChart.setOption(option1);

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

ECharts, PHP, MySQL, Ajax, JQuery 實現前后端數據可視化-36大數據
Tutorial測試

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

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

后臺處理

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

數據庫端MySQL

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

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

建立數據庫

PHP端

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

				<?php
				header("Content-type=text/json;charset=UTF-8");
				$conn = mysql_connect("localhost", "root", "mysql") or die("連接數據庫的過程失敗!");
				mysql_query("set names utf-8");
				mysql_select_db("test");
				$resultset = mysql_query("select name, age  from echartsuser", $conn);
				////////////////////////////////////////////////準備數據進行裝填
				$data = array();
				////////////////////////////////////////////////實體類
				class User{
				public $username;
				public $age;
				}
				////////////////////////////////////////////////處理
				while($row = mysql_fetch_array($resultset, MYSQL_ASSOC)) {
				$user = new User();
				$user->username = $row['name'];
				$user->age = $row['age'];
				$data[] = $user;
				}
				$conn.close();
				// 返回JSON類型的數據
				echo json_encode($data);
			

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

ECharts, PHP, MySQL, Ajax, JQuery 實現前后端數據可視化-36大數據
JSON接口測試

JQuery & Ajax處理

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

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

				// 初始化兩個數組,盛裝從數據庫中獲取到的數據
				var names = [], ages = [];
				//調用ajax來實現異步的加載數據
				function getusers() {
				$.ajax({
				type: "post",
				async: false,
				url: "../app/getuser.php",
				data: {},
				dataType: "json",
				success: function(result){
				if(result){
				for(var i = 0 ; i < result.length; i++){
				names.push(result[i].username);
				ages.push(result[i].age);
				}
				}
				},
				error: function(errmsg) {
				alert("Ajax獲取服務器數據出錯了!"+ errmsg);
				}
				});
				return names, ages;
				}
				// 執行異步請求
				getusers();
			

ECharts 端處理

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

				// 初始化 圖表對象
				var mychart = echarts.init(document.getElementById("container"));
				// 進行相關項的設置,也就是所謂的搭搭骨架,方便待會的ajax異步的數據填充
				var option = {
				title : {
				text : '姓名年齡分布圖'
				},
				tooltip : {
				show : true
				},
				legend : {
				data : [ 'age' ]
				},
				xAxis : [ {
				data : names
				} ],
				yAxis : [ {
				type : 'value'
				} ],
				series : [ {
				"name" : "age",
				"type" : "bar",
				"data" : ages
				} ]
				};
				// 將配置項賦給chart對象,來顯示相關的數據
				mychart.setOption(option);
			

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

前端全部代碼

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

				<!DOCTYPE html>
				<html>
				<head>
				<meta charset="UTF-8">
				<title>JQuery Ajax Test</title>
				<script src="../static/js/echarts.js"></script>
				<script src="../static/js/jquery-1.11.1.min.js"></script>
				</head>
				<body>
				<h1>PHP Ajax ECahrts 測試</h1>
				<hr>
				// 初始化兩個數組,盛裝從數據庫中獲取到的數據
				var names = [], ages = [];
				//調用ajax來實現異步的加載數據
				function getusers() {
				$.ajax({
				type: "post",
				async: false,
				url: "../app/getuser.php",
				data: {},
				dataType: "json",
				success: function(result){
				if(result){
				for(var i = 0 ; i < result.length; i++){
				names.push(result[i].username);
				ages.push(result[i].age);
				}
				}
				},
				error: function(errmsg) {
				alert("Ajax獲取服務器數據出錯了!"+ errmsg);
				}
				});
				return names, ages;
				}
				// 執行異步請求
				getusers();
				// 初始化 圖表對象
				var mychart = echarts.init(document.getElementById("container"));
				// 進行相關項的設置,也就是所謂的搭搭骨架,方便待會的ajax異步的數據填充
				var option = {
				title : {
				text : '姓名年齡分布圖'
				},
				tooltip : {
				show : true
				},
				legend : {
				data : [ 'age' ]
				},
				xAxis : [ {
				data : names
				} ],
				yAxis : [ {
				type : 'value'
				} ],
				series : [ {
				"name" : "age",
				"type" : "bar",
				"data" : ages
				} ]
				};
				// 將配置項賦給chart對象,來顯示相關的數據
				mychart.setOption(option);
				</script>
				<marquee>確認可以到達這里啊</marquee>
				</body>
				</html>
			

演示結果

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

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

效果演示圖

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

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

修改完數據

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

更新之后的數據

總結

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

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

End.

轉載請注明來自36大數據(36dsj.com): 36大數據 ? ECharts, PHP, MySQL, Ajax, JQuery 實現前后端數據可視化

隨意打賞

大數據可視化工具數據可視化軟件數據可視化分析數據可視化案例大數據可視化數據可視化
提交建議
微信掃一掃,分享給好友吧。
主站蜘蛛池模板: 成都顶呱呱信息技术有限公司-贷款_个人贷款_银行贷款在线申请 - 成都贷款公司 | 空气弹簧|橡胶气囊|橡胶空气弹簧-上海松夏减震器有限公司 | 液压升降货梯_导轨式升降货梯厂家_升降货梯厂家-河南东圣升降设备有限公司 | 气动调节阀,电动调节阀,自力式压力调节阀,切断阀「厂家」-浙江利沃夫自控阀门 | 生态板-实木生态板-生态板厂家-源木原作生态板品牌-深圳市方舟木业有限公司 | 本安接线盒-本安电路用接线盒-本安分线盒-矿用电话接线盒-JHH生产厂家-宁波龙亿电子科技有限公司 | 苏商学院官网 - 江苏地区唯一一家企业家自办的前瞻型、实操型商学院 | 工控机-工业平板电脑-研华工控机-研越无风扇嵌入式box工控机 | 彼得逊采泥器-定深式采泥器-电动土壤采样器-土壤样品风干机-常州索奥仪器制造有限公司 | 全自动实验室洗瓶机,移液管|培养皿|进样瓶清洗机,清洗剂-广州摩特伟希尔机械设备有限责任公司 | 工业淬火油烟净化器,北京油烟净化器厂家,热处理油烟净化器-北京众鑫百科 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 钢格栅板_钢格板网_格栅板-做专业的热镀锌钢格栅板厂家-安平县迎瑞丝网制造有限公司 | 纯化水设备-EDI-制药-实验室-二级反渗透-高纯水|超纯水设备 | 东莞市天进机械有限公司-钉箱机-粘箱机-糊箱机-打钉机认准东莞天进机械-厂家直供更放心! | 【直乐】河北石家庄脊柱侧弯医院_治疗椎间盘突出哪家医院好_骨科脊柱外科专业医院_治疗抽动症/关节病骨伤权威医院|排行-直乐矫形中医医院 | 电梯乘运质量测试仪_电梯安全评估测试仪-武汉懿之刻 | 润滑油加盟_润滑油厂家_润滑油品牌-深圳市沃丹润滑科技有限公司 琉璃瓦-琉璃瓦厂家-安徽盛阳新型建材科技有限公司 | 2025世界机器人大会_IC China_半导体展_集成电路博览会_智能制造展览网 | 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 纸箱抗压机,拉力机,脂肪测定仪,定氮仪-山东德瑞克仪器有限公司 | 电缆桥架生产厂家_槽式/梯式_热镀锌线槽_广东东莞雷正电气 | [官网]叛逆孩子管教_戒网瘾学校_全封闭问题青少年素质教育_新起点青少年特训学校 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 云南标线|昆明划线|道路标线|交通标线-就选云南云路施工公司-云南云路科技有限公司 | 精密线材测试仪-电线电缆检测仪-苏州欣硕电子科技有限公司 | 气力输送_输送机械_自动化配料系统_负压吸送_制造主力军江苏高达智能装备有限公司! | 法钢特种钢材(上海)有限公司 - 耐磨钢板、高强度钢板销售加工 阀门智能定位器_电液动执行器_气动执行机构-赫尔法流体技术(北京)有限公司 | 球盟会·(中国)官方网站 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | Copeland/谷轮压缩机,谷轮半封闭压缩机,谷轮涡旋压缩机,型号规格,技术参数,尺寸图片,价格经销商 CTP磁天平|小电容测量仪|阴阳极极化_双液系沸点测定仪|dsj电渗实验装置-南京桑力电子设备厂 | 浩方智通 - 防关联浏览器 - 跨境电商浏览器 - 云雀浏览器 | 烟气换热器_GGH烟气换热器_空气预热器_高温气气换热器-青岛康景辉 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 北京易通慧公司从事北京网站优化,北京网络推广、网站建设一站式服务商-北京网站优化公司 | 广东恩亿梯电源有限公司【官网】_UPS不间断电源|EPS应急电源|模块化机房|电动汽车充电桩_UPS电源厂家(恩亿梯UPS电源,UPS不间断电源,不间断电源UPS) | 楼梯定制_楼梯设计施工厂家_楼梯扶手安装制作-北京凌步楼梯 | 天津热油泵_管道泵_天津高温热油泵-天津市金丰泰机械泵业有限公司【官方网站】 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 南京种植牙医院【官方挂号】_南京治疗种植牙医院那个好_南京看种植牙哪里好_南京茀莱堡口腔医院 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 |