PHP+mysql+Highcharts生成饼状图


Posted in Javascript onMay 04, 2015

PHP+mysql+Highcharts生成饼状图

Mysql

首先我们建一张·chart_pie·表作为统计数据。

-- 
-- 表的结构 `chart_pie` 
-- 
 
CREATE TABLE IF NOT EXISTS `chart_pie` ( 
 `id` int(11) NOT NULL AUTO_INCREMENT, 
 `title` varchar(30) NOT NULL, 
 `pv` int(10) NOT NULL, 
 PRIMARY KEY (`id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=7 ; 
 
-- 
-- 转存表中的数据 `chart_pie` 
-- 
 
INSERT INTO `chart_pie` (`id`, `title`, `pv`) VALUES 
(1, '百度', 1239), 
(2, 'google', 998), 
(3, '搜搜', 342), 
(4, '必应', 421), 
(5, '搜狗', 259), 
(6, '其他', 83);

PHP

在pie.php我们要生成数据给前端调用:

$query = mysql_query("select * from chart_pie"); 
while($row = mysql_fetch_array($query)){ 
 $arr[] = array( 
  $row['title'],intval($row['pv']) 
 ); 
} 
$data = json_encode($arr);
jQuery
$(function() { 
 $('#highcharts').highcharts({ 
  chart: { 
   renderTo: 'chart_pie', 
   //饼状图关联html元素id值 
   defaultSeriesType: 'pie', 
   //默认图表类型为饼状图 
   plotBackgroundColor: '#ffc', 
   //设置图表区背景色 
   plotShadow: true //设置阴影 
  }, 
  title: { 
   text: '搜索引擎统计分析' //图表标题 
  }, 
  credits: { 
   text: '3water.com' 
  }, 
  tooltip: { 
   formatter: function() { //鼠标滑向图像提示框的格式化提示信息 
    return '<b>' + this.point.name + '</b>: ' + twoDecimal(this.percentage) + ' %'; 
   } 
  }, 
  plotOptions: { 
   pie: { 
    allowPointSelect: true, 
    //允许选中,点击选中的扇形区可以分离出来显示 
    cursor: 'pointer', 
    //当鼠标指向扇形区时变为手型(可点击) 
    //showInLegend: true, //如果要显示图例,可将该项设置为true 
    dataLabels: { 
     enabled: true, 
     //设置数据标签可见,即显示每个扇形区对应的数据 
     color: '#000000', 
     //数据显示颜色 
     connectorColor: '#999', 
     //设置数据域扇形区的连接线的颜色 
     style: { 
      fontSize: '12px' //数据显示的大小 
     }, 
     formatter: function() { //格式化数据 
      return '<b>' + this.point.name + '</b>: ' + twoDecimal(this.percentage) + ' %'; 
      //return '<b>' + this.point.name + '</b>: ' + this.y ; 
     } 
    } 
   } 
  }, 
  series: [{ //数据列 
   name: 'search engine', 
   data: data //核心数据列来源于php读取的数据并解析成JSON 
  }] 
 }); 
});

此外,格式化数据市,如果要显示百分比,可使用this.percentage,Highcharts会自动将整数转换为百分数,如果要显示数据量,直接使用this.y。
百分比代码如下:

formatter: function() { //格式化数据 
 return '<b>' + this.point.name + '</b>: ' + twoDecimal(this.percentage) + ' %'; 
}

实际数据是这样的:

formatter: function() { //格式化数据 
 return '<b>' + this.point.name + '</b>: ' + this.y ; 
}

最后我们要保留两位小数,代码贴下:

function twoDecimal(x) { //保留2位小数 
 var f_x = parseFloat(x); 
 if (isNaN(f_x)) { 
  alert('错误的参数'); 
  return false; 
 } 
 var f_x = Math.round(x * 100) / 100; 
 var s_x = f_x.toString(); 
 var pos_decimal = s_x.indexOf('.'); 
 if (pos_decimal < 0) { 
  pos_decimal = s_x.length; 
  s_x += '.'; 
 } 
 while (s_x.length <= pos_decimal + 2) { 
  s_x += '0'; 
 } 
 return s_x; 
}

柱状图、饼状图、曲线图等都是一样的。

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
javascript Demo模态窗口
Dec 06 Javascript
function foo的原型与prototype属性解惑
Nov 19 Javascript
js获取多个tagname的节点数组
Sep 22 Javascript
javascript的函数劫持浅析
Sep 26 Javascript
jQuery中Nicescroll滚动条插件的用法
Nov 10 Javascript
JS求解三元一次方程组值的方法
Jan 03 Javascript
Angular 4 指令快速入门教程
Jun 07 Javascript
vue2.0 自定义日期时间过滤器
Jun 07 Javascript
React-Native中禁用Navigator手势返回的示例代码
Sep 09 Javascript
vue-quill-editor富文本编辑器简单使用方法
Sep 21 Javascript
JavaScript中BOM对象原理与用法分析
Jul 09 Javascript
javascript前端实现多视频上传
Dec 13 Javascript
jQuery实现仿Google首页拖动效果的方法
May 04 #Javascript
js检测判断日期大于多少天的方法
May 04 #Javascript
jQuery实现表格展开与折叠的方法
May 04 #Javascript
JS数字抽奖游戏实现方法
May 04 #Javascript
JS实现跟随鼠标立体翻转图片的方法
May 04 #Javascript
js实现使用鼠标拖拽切换图片的方法
May 04 #Javascript
js实现每日自动换一张图片的方法
May 04 #Javascript
You might like
扩展你的 PHP 之入门篇
2006/12/04 PHP
PHP单链表的实现代码
2016/07/05 PHP
php 使用fopen函数创建、打开文件详解及实例代码
2016/09/24 PHP
Javascript拓展String方法小结
2013/07/08 Javascript
JS获取当前网址、主机地址项目根路径
2013/11/19 Javascript
jQuery入门之层次选择器实例简析
2015/12/11 Javascript
通过隐藏iframe实现无刷新上传文件操作
2016/03/16 Javascript
canvas实现十二星座星空图
2017/02/14 Javascript
springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项
2017/04/23 Javascript
AngularJS动态绑定ng-options的ng-model实例代码
2017/06/21 Javascript
jQuery Validate格式验证功能实例代码(包括重名验证)
2017/07/18 jQuery
JS实现的计数排序与基数排序算法示例
2017/12/04 Javascript
vscode中vue-cli项目es-lint的配置方法
2018/07/30 Javascript
jquery实现的分页显示功能示例
2019/08/23 jQuery
vue-cli+iview项目打包上线之后图标不显示问题及解决方法
2019/10/16 Javascript
Javascript中Math.max和Math.max.apply的区别和用法详解
2020/08/24 Javascript
python刷投票的脚本实现代码
2014/11/08 Python
Python学习教程之常用的内置函数大全
2017/07/14 Python
Python实现学校管理系统
2018/01/11 Python
Python对List中的元素排序的方法
2018/04/01 Python
OpenCV2从摄像头获取帧并写入视频文件的方法
2018/08/03 Python
python导入pandas具体步骤方法
2019/06/23 Python
python爬虫神器Pyppeteer入门及使用
2019/07/13 Python
法国美发器材和产品购物网站:Beauty Coiffure
2016/12/05 全球购物
Stuarts London美国/加拿大:世界领先的独立男装零售商之一
2019/03/18 全球购物
一道SQL面试题
2012/12/31 面试题
是否可以从一个static方法内部发出对非static方法的调用?
2014/08/18 面试题
室内趣味活动方案
2014/08/24 职场文书
节能环保演讲稿
2014/08/28 职场文书
房地产营销活动策划方案
2014/09/15 职场文书
预备党员转正意见
2015/06/01 职场文书
小学三年级数学教学反思
2016/02/16 职场文书
2019毕业论文致谢词
2019/06/24 职场文书
Python机器学习之决策树和随机森林
2021/07/15 Javascript
详解redis在微服务领域的贡献
2021/10/16 Redis
Windows Server 2012配置DNS服务器的方法
2022/04/29 Servers