最近要将后台数据库上的一些数据以可视化的方法显示到前端,找来找去,发现百度开发的这套图表工具库还不错,网上搜索了一下相关的教程,也算是实现了较为简单的demo。于是写下来,记录一下。

ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化 JQuery实现前后端数据可视化(echarts后端数据交互)  大数据 数据可视化 前后端 第1张

最近要将后台数据库上的一些数据以可视化的方法显示到前端,找来找去,发现百度开发的这套图表工具库还不错,网上搜索了一下相关的教程,也算是实现了较为简单的demo。于是写下来,记录一下。

ECharts

ECharts是国人开发的一套前端的图表工具库,使用起来超方便,也很简单(当然了,前提是理解了其工作原理之后)。

下面简单的介绍一下,如何在项目中使用ECharts。

下载js代码

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

个人觉得,开发人员下载完整版会比较好一点。而且官方建议的也是下载完整版。

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第2张

下载Echarts

博主这里下载的是完整版,大约不到2M。

工作原理浅析

其实仔细的想想,ECharts的工作就是在网页上显示了一张特殊的图片嘛。所以我们需要意识到,需要给“图片”一个一个空间,这样才会有图表的安家之所嘛。

然后空间有了,也就是有地皮了。要盖一个房子的话,必须得有框架不是。这样的往上面添加些砖瓦水泥什么的才能将房子盖起来。同样的,ECharts也是这么个原理。但是这个“骨架”叫Option。至于这个option需要怎么设置,官网上有详细的介绍,博主就不再这里重复的造轮子了。大家有兴趣的可以到下图展示的地方去学习。

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第3张

ECharts3下载

在项目中引入ECharts

如题,本小节就是大致的讲一下如何简单的使用这个图标库。

不妨看一下下面的代码:

  1. <!DOCTYPEhtml>
  2. <html>
  3. <head>
  4. <metacharset="UTF-8">
  5. <title>入门</title>
  6. <scriptsrc="../static/js/echarts.js"></script>
  7. <scriptsrc="../static/js/sleeplib.js"></script>
  8. </head>
  9. <body>
  10. <h1>开始测试</h1>
  11. <hr>
  12. <!--先准备一个用于盛放图表的容器-->
  13. //通过echarts.init方法初始化一个echarts实例并通过setOption方法生成一个简单的柱状图
  14. //基于准备好的DOM,实例化echarts实例
  15. varmyChart=echarts.init(document.getElementById("container"));
  16. //指定图表的配置项和数据
  17. varoption1={
  18. title:{
  19. text:'ECharts入门案例'
  20. },
  21. tooltip:{
  22. text:'鼠标放上去之后的悬浮提示语句!'
  23. },
  24. legend:{
  25. data:['销量']
  26. },
  27. xAxis:{
  28. data:['衬衫','羊毛衫','雪纺衫','裤子','高跟鞋','袜子','内裤']
  29. },
  30. yAxis:{},
  31. series:[{
  32. name:'销量',
  33. type:'bar',
  34. data:[7,20,36,10,10,20,28]
  35. }]
  36. };
  37. //使用上面的配置项作为参数,传给echart来显示
  38. myChart.setOption(option1);
  39. </script>
  40. </body>
  41. </html>

关键在于***一句:

  1. myChart.setOption(option1);

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

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第4张

Tutorial测试

另外手动的点击上面的那个legend为“销量”的小红色的矩形,会有惊喜的哟。

<marquee><font color=”green” size=’6′>接下来开始进入今天的正题</font></marquee>

后台处理

后台处理包括使用PHP查询数据库,然后以数组的形式返回,再由JQuery以Ajax的形式获取数据,交给前端进行显示的过程。

数据库端MySQL

数据是核心,所以建库很重要。这里仅仅是为了演示,所以数据库建的很简单,如下图:

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第5张

建立数据库

PHP端

需要注意的是,数据库端返回的时候必须是JSON类型,这样才可以被ajax处理的更方便。

  1. <?php
  2. header("Content-type=text/json;charset=UTF-8");
  3. $conn=mysql_connect("localhost","root","mysql")ordie("连接数据库的过程失败!");
  4. mysql_query("setnamesutf-8");
  5. mysql_select_db("test");
  6. $resultset=mysql_query("selectname,agefromechartsuser",$conn);
  7. ////////////////////////////////////////////////准备数据进行装填
  8. $data=array();
  9. ////////////////////////////////////////////////实体类
  10. classUser{
  11. public$username;
  12. public$age;
  13. }
  14. ////////////////////////////////////////////////处理
  15. while($row=mysql_fetch_array($resultset,MYSQL_ASSOC)){
  16. $user=newUser();
  17. $user->username=$row['name'];
  18. $user->age=$row['age'];
  19. $data[]=$user;
  20. }
  21. $conn.close();
  22. //返回JSON类型的数据
  23. echojson_encode($data);

那么验证返回的数据类型到底是不是JSON,我们只需要做下接口测试即可。博主使用的是Chrome浏览器,装了一个JSON的插件,所以可以很方便的检测。如下图:

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第6张

JSON接口测试

JQuery & Ajax处理

JQuery真的是难的的一个函数工具库,因此使用JQuery处理起来ajax请求会降低代码编写的复杂度,其底层将自动的处理兼容性问题。这很GEEK。

本例,目的很明确,获取刚才的数据接口内的数据。所以代码很简单,如下:

  1. //初始化两个数组,盛装从数据库中获取到的数据
  2. varnames=[],ages=[];
  3. //调用ajax来实现异步的加载数据
  4. functiongetusers(){
  5. $.ajax({
  6. type:"post",
  7. async:false,
  8. url:"../app/getuser.php",
  9. data:{},
  10. dataType:"json",
  11. success:function(result){
  12. if(result){
  13. for(vari=0;i<result.length;i++){
  14. names.push(result[i].username);
  15. ages.push(result[i].age);
  16. }
  17. }
  18. },
  19. error:function(errmsg){
  20. alert("Ajax获取服务器数据出错了!"+errmsg);
  21. }
  22. });
  23. returnnames,ages;
  24. }
  25. //执行异步请求
  26. getusers();

ECharts 端处理

现在“万事俱备,只欠东风”了,数据都已经有了,剩下的就是如何显示它们了。按照一开始博主的盖房子理论,下面就把骨架搭起来吧。

  1. //初始化图表对象
  2. varmychart=echarts.init(document.getElementById("container"));
  3. //进行相关项的设置,也就是所谓的搭搭骨架,方便待会的ajax异步的数据填充
  4. varoption={
  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. //将配置项赋给chart对象,来显示相关的数据
  27. mychart.setOption(option);

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

前端全部代码

个人觉得有个完整的代码会给人不少的启发,那么这里还是贴出前端交互的代码吧,也方便大家查看。

  1. <!DOCTYPEhtml>
  2. <html>
  3. <head>
  4. <metacharset="UTF-8">
  5. <title>JQueryAjaxTest</title>
  6. <scriptsrc="../static/js/echarts.js"></script>
  7. <scriptsrc="../static/js/jquery-1.11.1.min.js"></script>
  8. </head>
  9. <body>
  10. <h1>PHPAjaxECahrts测试</h1>
  11. <hr>
  12. //初始化两个数组,盛装从数据库中获取到的数据
  13. varnames=[],ages=[];
  14. //调用ajax来实现异步的加载数据
  15. functiongetusers(){
  16. $.ajax({
  17. type:"post",
  18. async:false,
  19. url:"../app/getuser.php",
  20. data:{},
  21. dataType:"json",
  22. success:function(result){
  23. if(result){
  24. for(vari=0;i<result.length;i++){
  25. names.push(result[i].username);
  26. ages.push(result[i].age);
  27. }
  28. }
  29. },
  30. error:function(errmsg){
  31. alert("Ajax获取服务器数据出错了!"+errmsg);
  32. }
  33. });
  34. returnnames,ages;
  35. }
  36. //执行异步请求
  37. getusers();
  38. //初始化图表对象
  39. varmychart=echarts.init(document.getElementById("container"));
  40. //进行相关项的设置,也就是所谓的搭搭骨架,方便待会的ajax异步的数据填充
  41. varoption={
  42. title:{
  43. text:'姓名年龄分布图'
  44. },
  45. tooltip:{
  46. show:true
  47. },
  48. legend:{
  49. data:['age']
  50. },
  51. xAxis:[{
  52. data:names
  53. }],
  54. yAxis:[{
  55. type:'value'
  56. }],
  57. series:[{
  58. "name":"age",
  59. "type":"bar",
  60. "data":ages
  61. }]
  62. };
  63. //将配置项赋给chart对象,来显示相关的数据
  64. mychart.setOption(option);
  65. </script>
  66. <marquee>确认可以到达这里啊</marquee>
  67. </body>
  68. </html>

演示结果

至此,编码任务就算完成了。那么迫不及待的来看看效果吧。

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第7张

效果演示图

那么,稍微的修改一下数据,再来看看结果会怎样,刷新之后如下图:

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第8张

修改完数据

 ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互) 大数据 数据可视化 前后端 第9张

更新之后的数据

总结

***来回顾一下,本次试验的收获。其实也就是对于ECharts的一个比较“全栈”(请允许我用了这么个不太恰当的词 O(∩_∩)O ) 。比较简单的实现了后端以及前端的数据可视化显示的一个流程。

用到的技术也都是很大众化的了,当然后端不仅可以由PHP来完成,JAVA,Python,Golang等等都是可以的,只是使用PHP比较方便罢了。只要可以根据这个接口获取到想要的数据就行。

转载请说明出处
知优网 » ECharts, PHP, MySQL, Ajax, JQuery实现前后端数据可视化(echarts后端数据交互)

发表评论

您需要后才能发表评论