Highcharts+PHP+Mysql生成饼状统计图

2当家的 发布于 2017/03/19 15:21
阅读 126
收藏 3

演示下载地址:http://www.erdangjiade.com/js/50.html
效果图:

  1. Mysql
  2.  
  3. 首先我们建一张·chart_pie·表作为统计数据。
  4.  
  5. -- 
  6. -- 表的结构 `chart_pie` 
  7. -- 
  8.  
  9. CREATE TABLE IF NOT EXISTS `chart_pie` ( 
  10.   `id` int(11) NOT NULL AUTO_INCREMENT, 
  11.   `title` varchar(30) NOT NULL, 
  12.   `pv` int(10) NOT NULL, 
  13.   PRIMARY KEY (`id`) 
  14. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=7 ; 
  15.  
  16. -- 
  17. -- 转存表中的数据 `chart_pie` 
  18. -- 
  19.  
  20. INSERT INTO `chart_pie` (`id`, `title`, `pv`) VALUES 
  21. (1, '百度', 1239), 
  22. (2, 'google', 998), 
  23. (3, '搜搜', 342), 
  24. (4, '必应', 421), 
  25. (5, '搜狗', 259), 
  26. (6, '其他', 83);
  27.  
  28. PHP
  29.  
  30. 在pie.php我们要生成数据给前端调用:
  31.  
  32. $query = mysql_query("select * from chart_pie");  
  33. while($row = mysql_fetch_array($query)){  
  34.     $arr[] = array(  
  35.         $row['title'],intval($row['pv'])  
  36.     );  
  37. }  
  38. $data = json_encode($arr);
  39.  
  40. jQuery
  41.  
  42. $(function() { 
  43.     $('#highcharts').highcharts({ 
  44.         chart: { 
  45.             renderTo: 'chart_pie', 
  46.             //饼状图关联html元素id值 
  47.             defaultSeriesType: 'pie', 
  48.             //默认图表类型为饼状图 
  49.             plotBackgroundColor: '#ffc', 
  50.             //设置图表区背景色 
  51.             plotShadow: true //设置阴影 
  52.         }, 
  53.         title: { 
  54.             text: '搜索引擎统计分析' //图表标题 
  55.         }, 
  56.         credits: { 
  57.             text: 'erdangjiade.com' 
  58.         }, 
  59.         tooltip: { 
  60.             formatter: function() { //鼠标滑向图像提示框的格式化提示信息 
  61.                 return '<b>' + this.point.name + '</b>: ' + twoDecimal(this.percentage) + ' %'; 
  62.             } 
  63.         }, 
  64.         plotOptions: { 
  65.             pie: { 
  66.                 allowPointSelect: true, 
  67.                 //允许选中,点击选中的扇形区可以分离出来显示 
  68.                 cursor: 'pointer', 
  69.                 //当鼠标指向扇形区时变为手型(可点击) 
  70.                 //showInLegend: true,  //如果要显示图例,可将该项设置为true 
  71.                 dataLabels: { 
  72.                     enabled: true, 
  73.                     //设置数据标签可见,即显示每个扇形区对应的数据 
  74.                     color: '#000000', 
  75.                     //数据显示颜色 
  76.                     connectorColor: '#999', 
  77.                     //设置数据域扇形区的连接线的颜色 
  78.                     style: { 
  79.                         fontSize: '12px' //数据显示的大小 
  80.                     }, 
  81.                     formatter: function() { //格式化数据 
  82.                         return '<b>' + this.point.name + '</b>: ' + twoDecimal(this.percentage) + ' %'; 
  83.                         //return '<b>' + this.point.name + '</b>: ' + this.y ; 
  84.                     } 
  85.                 } 
  86.             } 
  87.         }, 
  88.         series: [{ //数据列 
  89.             name: 'search engine', 
  90.             data: data //核心数据列来源于php读取的数据并解析成JSON 
  91.         }] 
  92.     }); 
  93. });
  94.  
  95. 此外,格式化数据市,如果要显示百分比,可使用this.percentage,Highcharts会自动将整数转换为百分数,如果要显示数据量,直接使用this.y。
  96.  
  97. 百分比代码如下:
  98.  
  99. formatter: function() { //格式化数据  
  100.     return '<b>' + this.point.name + '</b>: ' + twoDecimal(this.percentage) + ' %';  
  101. }
  102.  
  103. 实际数据是这样的:
  104.  
  105. formatter: function() { //格式化数据  
  106.     return '<b>' + this.point.name + '</b>: ' + this.y ;  
  107. }
  108.  
  109. 最后我们要保留两位小数,代码贴下:
  110.  
  111. function twoDecimal(x) { //保留2位小数 
  112.     var f_x = parseFloat(x); 
  113.     if (isNaN(f_x)) { 
  114.         alert('错误的参数'); 
  115.         return false; 
  116.     } 
  117.     var f_x = Math.round(x * 100) / 100; 
  118.     var s_x = f_x.toString(); 
  119.     var pos_decimal = s_x.indexOf('.'); 
  120.     if (pos_decimal < 0) { 
  121.         pos_decimal = s_x.length; 
  122.         s_x += '.'; 
  123.     } 
  124.     while (s_x.length <= pos_decimal + 2) { 
  125.         s_x += '0'; 
  126.     } 
  127.     return s_x; 
  128. }
加载中
返回顶部
顶部