Think PHP:异步更新ECharts图表数据

前言

在对一个以Think PHP为基础的网站源码进行改动时,由于其没有数据统计的功能,我想着在其代码的基础上机上这个功能。当然,数据统计的结果最好能够以图表的形式显示出来。经过在网上搜索之后,我选择了EChart,其是个开源的数据可视化JavaScript库,操作简单,使用方便。

ECharts下载使用

官网介绍:
ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Firefox,Safari等),底层依赖轻量级的 Canvas 类库 [ZRender (https://github.com/ecomfe/zrender),提供直观,生动,可交互,可高度个性化定制的数据可视化图表。
ECharts 3 中更是加入了更多丰富的交互功能以及更多的可视化效果,并且对移动端做了深度的优化。

官网给出了很多示例,效果非常酷炫而且支持实时互动。其基本的工作原理是使用HTMLdiv标签作为容器来承载图表。在下载时会发现提供了4种下载版本,这里推荐大家使用“源代码”版本,方便调试。

image.png

官方教程中给出了一个Demo源码:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>ECharts</title>
    <!-- 引入 echarts.js -->
    <script src="echarts.min.js"></script>
</head>
<body>
    <!-- 为ECharts准备一个具备大小(宽高)的Dom -->
    <div id="main" style="width: 600px;height:400px;"></div>
    <script type="text/javascript">
        // 基于准备好的dom,初始化echarts实例
        var myChart = echarts.init(document.getElementById('main'));

        // 指定图表的配置项和数据
        var option = {
            title: {
                text: 'ECharts 入门示例'
            },
            tooltip: {},
            legend: {
                data:['销量']
            },
            xAxis: {
                data: ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"]
            },
            yAxis: {},
            series: [{
                name: '销量',
                type: 'bar',
                data: [5, 20, 36, 10, 10, 20]
            }]
        };

        // 使用刚指定的配置项和数据显示图表。
        myChart.setOption(option);
    </script>
</body>
</html>

显示效果为:(可以看到在鼠标滑过时可以实时显示真实数据)

image.png

异步更新ECharts图表数据

由上述给出的Demo可以看出,Y轴的数据由series中的data项给出,X轴的数据由xAxis中的data给出。在实际使用时,数据不可能在代码中给出,我们往往需要在数据库中查找数据之后进行显示。这种情况下就需要异步加载数据,ECharts 中可以通过jQuery等工具异步获取数据后通过 setOption 将数据填入data项即可。
(附官网给出的异步加载示例)

var myChart = echarts.init(document.getElementById('main'));
// 显示标题,图例和空的坐标轴
myChart.setOption({
    title: {
        text: '异步数据加载示例'
    },
    tooltip: {},
    legend: {
        data:['销量']
    },
    xAxis: {
        data: []
    },
    yAxis: {},
    series: [{
        name: '销量',
        type: 'bar',
        data: []
    }]
});

// 异步加载数据
$.get('data.json').done(function (data) {
    // 填入数据
    myChart.setOption({
        xAxis: {
            data: data.categories
        },
        series: [{
            // 根据名字对应到相应的系列
            name: '销量',
            data: data.data
        }]
    });
});

Think PHP下的配置使用

本次示例使用的Think PHP的版本为3.2.3,目前其最新的版本为5.0.10,不过对于基本功能来说两者的区别不大,所以就算是与我的版本不同,代码也基本上可以运行。(点击下载Think PHP3.2.3
下载完成之后,我们需要安装本地服务器WAMPServer,点击进入官网进行下载安装即可,这里不再做过多说明。

注:本地服务器也有其它的软件可以选择,如XAMPWAMPServer属于集成环境,即其包含ApachePHPMySql,使用很方便。当然也可以选择安装这三个软件,使用效果是一样的。
3.2.3版本的快速入门教程ThinkPHP3.2.3快速入门

WAMPServer安装运行之后,会在右下角任务栏处出现一个W型的图标,默认是英文版的,右键可以选择中文语言。然后将下载后的Think PHP代码包放入WAMPServerwww目录,这个就是你服务器的根目录。(ThinkPHPOrigin即是Think PHP的代码包,我这里改了名字)

image.png

这一步完成之后,在浏览器地址栏中输入http://localhost/ThinkPHPOrigin/Home/Index/index,可以看到:

image.png

说明Think PHP已经配置成功!
下面我们开始写代码(●ˇ∀ˇ●)
首先在Home/Controller目录中建立一个新的控制器,文件名为ChartsController.class.php,内容为:

<?php
namespace Home\Controller;
use Think\Controller;
class ChartsController extends Controller{
    public function index(){
        $this->display();
    }

    public function getData(){
        //数据应该从数据库中取出,这里采用直接赋值的方式,和使用数据库时代码一样
        $data['categories']  = array("衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子");
        $data['data'] = array(5, 20, 36, 10, 10, 20);
        $this->ajaxReturn($data);
    }
    
    public function test(){
        echo "__APP__";
    }
}

在对应的Home/View/Charts目录下新建视图文件,index.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>JQuery Ajax Test</title>
<!-- ECharts的js文件 -->
<script src="__PUBLIC__/js/echarts.js"></script>
<!-- JQuery的js文件 -->
<script src="__PUBLIC__/js/jquery-1.4.4.min.js"></script>
<style>
    body{ text-align:center} /* 使div居中显示 */
    #container{margin:0 auto;border:1px solid #000;width:600px;height:400px} 
</style>
</head>
<body>
    <h1>PHP Ajax ECahrts 测试</h1>
    <hr>
    <div id="container"></div>
<script>

var myChart = echarts.init(document.getElementById('container'));
// 显示标题,图例和空的坐标轴
myChart.setOption({
    title: {
        text: '异步数据加载示例'
    },
    tooltip: {},
    legend: {
        data:['销量']
    },
    xAxis: {
        data: []
    },
    yAxis: {},
    series: [{
        name: '销量',
        type: 'bar',
        center: ['100%', '50%'],
        data: []
    }]
});


$.ajax({
    url:"__CONTROLLER__/getData",//这里指向的就不再是页面了,而是一个方法。路径填写__CONTROLLER__/getData也正确
    data:{},
    type:"POST",
    dataType:"JSON",
    success: function(data){
        var obj = eval('(' + data + ')');//由JSON字符串转换为JSON对象
        myChart.setOption({
            xAxis: {
                data: obj.categories
            },
            series: [{
                // 根据名字对应到相应的系列
                name: '销量',
                data: obj.data
            }]
        });

    }
});

</script>

</body>
</html>

其中js文件均放在ThinkPHPOrigin\Public\js\路径下。
在浏览器地址栏中输入http://localhost/ThinkPHPOrigin/Home/Charts/index

image.png

结语

如果在部署Think PHP代码后,浏览器访问时出现404错误,可以参考Think PHP:Apache开启PATHINFO模式

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,089评论 4 62
  • Swift版本点击这里欢迎加入QQ群交流: 594119878最新更新日期:18-09-17 About A cu...
    ylgwhyh阅读 25,361评论 7 249
  • 冰丝面料真的是超级亲肤舒适,买了一款体验超级棒,所以准备给妈妈也买一套,相信她也会喜欢上这款内衣 @https:/...
    URoom一室一品阅读 127评论 0 0
  • 文/六雅 火树银花似万萤, 肆无忌惮舞秋庭。 瑞光夺目如昙现, 繁华过时自涕零。 (平水韵,仄起首句押韵)
    盘锦西山阅读 262评论 0 3
  • 梅小苏一边愉快地拆着快递盒,一边问我,“妙莲,你喜欢用钢笔吗?” 我正弯着腰卷着瑜伽垫,它又大又厚,摸起来肥肥软软...
    Lotusmiao阅读 629评论 6 19