返回highcha......登陆

highcharts图表重用

巴扎黑2017-01-11 10:41:35551

作者:张远靖
链接:https://www.zhihu.com/question/39857001/answer/84193997
来源:知乎
著作权归作者所有,转载请联系作者获得授权。

1、后端代码
后端只需要根据前端传过来的参数获取对应的数据并按照规定的数据格式返回即可,下面是简单的 php 代码,请参考

作者:张远靖
链接:https://www.zhihu.com/question/39857001/answer/84193997
来源:知乎
著作权归作者所有,转载请联系作者获得授权。

<?php 
 // 统计数据类型,有 年、周、日 
 $type = $_REQUEST['type']; 
 $data = array(); 
 $data['categories'] = array(); 
 $data['data'] =  array();
 // 针对不同的统计类型做处理 
 switch($type) {
case 'day' :
 //
 ;break; 
 case 'week':
 //
 ;break; 
 case 'year': 
 // 这里的代码仅供参考,保证最终返回的结果是 
 // {"categories":["2014","2015","2016"],"data":[2323,4343,23433]} 就行
 $data['categories'][0] = '2014'; 
 $data['data'][0] = 2323; 
 $data['categories'][1]= '2015';
 $data['data'][1] = 4343; 
 $data['categories'][2] ='2016';
 $data['data'][2] = 23433;
 ; break; 
 default;break;
 } 
 echo json_encode($data);
?>

后端返回的数据格式是:


{   

  "categories": ["2014", "2015", "2016"],     "data": [2323, 4343, 23433] 

}

2、前端代码

<!DOCTYPE html> <html> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">     li {         display: inline-block;         cursor: pointer;         background-color: #eee;         padding: 4px 6px;     }          .active {         color: red     }     </style> </head> <body>     <ul>         <li data-type="day">日</li>         <li data-type="week">周</li>         <li data-type="year">年</li>     </ul>     <div id="container"></div>     <script type="text/javascript" src="http://cdn.hcharts.cn/jquery/jquery-1.8.3.min.js"></script>     <script type="text/javascript" src="http://cdn.hcharts.cn/highcharts/highcharts.js"></script>     <script type="text/javascript">     var chart = null;     generateChart('day');     $('li').click(function() {         if ($(this).hasClass('active')) return false;         $('.active').removeClass('active');         generateChart($(this).data('type'));         $(this).addClass('active');     });     function generateChart(type) {         $.ajax({             url: 'php-data.php',             data: {                 type: type             },             success: function(data) {                 data = JSON.parse(data);                 if (chart) {                     // 更新操作                     chart.xAxis[0].UPDATE({                         categories: data.categories                     });                     chart.series[0].UPDATE({                         data: data.data                     });                 } else {                     // 初始化图表操作                     $('#container').highcharts({                         xAxis: {                             categories: data.categories                         },                         series: [{                             name: 'x',                             data: data.data                         }]                     }, function(c) {                         chart = c;                     })                 }             }         })     }     </script> </body> </html>

更多关于highcharts图表重用请关注PHP中文网(www.php.cn)其他文章!

最新手记推荐

• 用composer安装thinkphp框架的步骤• 省市区接口说明• 用thinkphp,后台新增栏目• 管理员添加编辑删除• 管理员添加编辑删除

全部回复(0)我要回复

暂无评论~
  • 取消回复发送