搜尋
首頁後端開發php教程PHP+mysql+Highcharts实现饼状统计图_PHP教程

PHP+mysql+Highcharts实现饼状统计图

PHP+mysql+Highcharts实现饼状统计图

data-cke-saved-src=http://www.bkjia.com/uploads/allimg/150704/042Z13211-0.png

Mysql
首先我们建一张?chart_pie?表作为统计数据。
-- edit http://www.lai18.com 
-- 表的结构 `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我们要生成数据给前端调用(参考:http://www.lai18.com/content/409203.html):
/* edit http://www.lai18.com
 * 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: 'jb51.net' 
  }, 
  tooltip: { 
   formatter: function() { //鼠标滑向图像提示框的格式化提示信息 
    return &#39;<b>&#39; + this.point.name + &#39;</b>: &#39; + twoDecimal(this.percentage) + &#39; %&#39;; 
   } 
  }, 
  plotOptions: { 
   pie: { 
    allowPointSelect: true, 
    //允许选中,点击选中的扇形区可以分离出来显示 
    cursor: &#39;pointer&#39;, 
    //当鼠标指向扇形区时变为手型(可点击) 
    //showInLegend: true, //如果要显示图例,可将该项设置为true 
    dataLabels: { 
     enabled: true, 
     //设置数据标签可见,即显示每个扇形区对应的数据 
     color: &#39;#000000&#39;, 
     //数据显示颜色 
     connectorColor: &#39;#999&#39;, 
     //设置数据域扇形区的连接线的颜色 
     style: { 
      fontSize: &#39;12px&#39; //数据显示的大小 
     }, 
     formatter: function() { //格式化数据 
      return &#39;<b>&#39; + this.point.name + &#39;</b>: &#39; + twoDecimal(this.percentage) + &#39; %&#39;; 
      //return &#39;<b>&#39; + this.point.name + &#39;</b>: &#39; + this.y ; 
     } 
    } 
   } 
  }, 
  series: [{ //数据列 
   name: &#39;search engine&#39;, 
   data: data //核心数据列来源于php读取的数据并解析成JSON 
  }] 
 }); 
});


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

百分比代码如下:
formatter: function() { //格式化数据 
 return &#39;<b>&#39; + this.point.name + &#39;</b>: &#39; + twoDecimal(this.percentage) + &#39; %&#39;; 
}


实际数据是这样的:
/* edit http://www.lai18.com
 * JS代码
 */
formatter: function() { //格式化数据 
 return &#39;<b>&#39; + this.point.name + &#39;</b>: &#39; + this.y ; 
}


最后我们要保留两位小数,代码贴下:
function twoDecimal(x) { //保留2位小数 
 var f_x = parseFloat(x); 
 if (isNaN(f_x)) { 
  alert(&#39;错误的参数&#39;); 
  return false; 
 } 
 var f_x = Math.round(x * 100) / 100; 
 var s_x = f_x.toString(); 
 var pos_decimal = s_x.indexOf(&#39;.&#39;); 
 if (pos_decimal < 0) { 
  pos_decimal = s_x.length; 
  s_x += &#39;.&#39;; 
 } 
 while (s_x.length <= pos_decimal + 2) { 
  s_x += &#39;0&#39;; 
 } 
 return s_x; 
}


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


更多JS插件

《JQuery常用插件教程》系列技术文章整理收藏

1使用jquery插件实现图片延迟加载技术详细说明

2纯JAVASCRIPT图表动画插件Highcharts Examples

3Highcharts-功能强大的图表库的应用

4Highcharts选项配置详细说明文档

5使用Highcharts生成折线图与曲线图

6使用Highcharts生成柱状图

7使用Highcharts结合PHP与Mysql生成饼状图

8使用Highcharts实现柱状图、饼状图、曲线图三图合一

9jQuery时间轴插件:jQuery Timelinr

10Zclip:复制页面内容到剪贴板兼容各浏览器

11Highcharts 非常实用的Javascript统计图demo示例

12iPictrue:图片标注提示

13使用jquery.qrcode生成二维码

14Highcharts报表插件多余小数位BUG的修复

15日程安排FullCalendar

16FullCalendar日历插件说明文档

17FullCalendar应用——读取JSON数据

18FullCalendar应用——新建日程事件

19FullCalendar应用——编辑与删除日程事件

20FullCalendar应用——拖动与实时保存

21JQuery Highcharts 动态生成图表的方法

22FullCalendar应用——整合农历节气和节日

23Highcharts图表库使用教程[Highcharts详细参数配置]

24浅析jquery的js图表组件highcharts

25使用jquery实现的一个图片延迟加载插件(含图片延迟加载原理)

26AMD异步模块定义介绍和Require.js中使用jQuery及jQuery插件的方法

27使用jquery.upload.js实现异步上传示例代码

28使用jquery.qrcode生成彩色二维码实例

29使用jquery.validate自定义方法实现手机号码或者固话至少填写一个的逻辑验证

30使用jQuery.wechat构建微信WEB应用

31使用JQ来编写最基本的淡入淡出效果附演示动画

32使用jquery菜单插件HoverTree仿京东无限级菜单

33使用jQuery jqPlot插件绘制柱状图

34SyntaxHighlighter 3.0.83使用笔记

35基于jQuery带备忘录功能的日期选择器

36JavaScript人脸检测的实现方法

37jQuery延迟加载(懒加载)插件 – jquery.lazyload.js

38在父页面得到zTree已选中的节点的方法

39使用jquery组件qrcode生成二维码及应用指南

40jQuery Highcharts折线图案例分析

41jquery.uploadify插件在chrome浏览器频繁崩溃解决方法

42jQuery.Highcharts.js绘制柱状图饼状图曲线图

43jQuery实现精美的多级下拉菜单特效

44jQuery实现加入购物车飞入动画效果

45jQuery+slidereveal实现的面板滑动侧边展出效果

46PHP+mysql+Highcharts生成饼状图

47AspNet中使用JQuery上传插件Uploadify详解

48AspNet中使用JQuery boxy插件的确认框

49ajax读取数据后使用jqchart显示图表的方法

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1026143.htmlTechArticlePHP+mysql+Highcharts实现饼状统计图 PHP+mysql+Highcharts实现饼状统计图 Mysql 首先我们建一张?chart_pie?表作为统计数据。 -- edit http://www.lai18.com -- 表...
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
PHP的完整形式是什麼?PHP的完整形式是什麼?Apr 28, 2025 pm 04:58 PM

文章討論了PHP,詳細介紹了其完整形式,在We​​b開發中的主要用途,與Python和Java的比較以及對初學者的學習便利性。

PHP如何處理形式數據?PHP如何處理形式數據?Apr 28, 2025 pm 04:57 PM

PHP使用$ \ _ post和$ \ _獲取超級全局的php處理數據,並通過驗證,消毒和安全數據庫交互確保安全性。

PHP和ASP.NET有什麼區別?PHP和ASP.NET有什麼區別?Apr 28, 2025 pm 04:56 PM

本文比較了PHP和ASP.NET,重點是它們對大規模Web應用程序,性能差異和安全功能的適用性。兩者對於大型項目都是可行的,但是PHP是開源和無關的,而ASP.NET,

PHP是對病例敏感的語言嗎?PHP是對病例敏感的語言嗎?Apr 28, 2025 pm 04:55 PM

PHP的情況敏感性各不相同:功能不敏感,而變量和類是敏感的。最佳實踐包括一致的命名和使用對案例不敏感的功能進行比較。

您如何重定向PHP中的頁面?您如何重定向PHP中的頁面?Apr 28, 2025 pm 04:54 PM

本文討論了PHP中針對頁面重定向的各種方法,重點關注header()函數,並解決了諸如“標題已經發送”錯誤之類的常見問題。

解釋PHP中的類型暗示解釋PHP中的類型暗示Apr 28, 2025 pm 04:52 PM

文章討論了PHP中的類型暗示,這是一個用於指定功能中預期數據類型的功能。主要問題是通過類型執法提高代碼質量和可讀性。

PHP中的PDO是什麼?PHP中的PDO是什麼?Apr 28, 2025 pm 04:51 PM

本文討論了PHP數據對象(PDO),這是PHP中數據庫訪問的擴展名。它通過準備好的語句及其對MySQLI的好處,包括數據庫抽象和更好的錯誤處理,強調了PDO在增強安全性方面的作用。

如何在PHP中創建API?如何在PHP中創建API?Apr 28, 2025 pm 04:50 PM

文章討論了創建和保護PHP API,詳細介紹了從端點定義到使用Laravel和最佳安全實踐等框架優化性能優化的步驟。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。