Highcharts使用简例及异步动态读取数据


Posted in Javascript onDecember 30, 2015

Highcharts 是一个用纯JavaScript编写的一个图表库, 能够很简单便捷的在web网站或是web应用程序添加有交互性的图表,并且免费提供给个人学习、个人网站和非商业用途使用。HighCharts支持的图表类型有曲线图、区域图、柱状图、饼状图、散状点图和综合图表。

第一部分:在head之间加载两个JS库。

<script src="html/js/jquery.js"></script>
<script src="html/js/chart/highcharts.js"></script>

可以到http://www.hcharts.cn/ 下载,有相关教程和使用说明文档。

英文好的可以去官网:http://www.highcharts.com/

第二部分:JS代码

//定义一个Highcharts的变量,初始值为null
var oChart = null;
//定义oChart的布局环境
//布局环境组成:X轴、Y轴、数据显示、图标标题
var oOptions = { 
 //设置图表关联显示块和图形样式
 chart: { 
  renderTo: 'container', //设置显示的页面块
  //type:'line'    //设置显示的方式
  type: 'column'
 },
 //图标标题
 title: { 
  text: '图表展示范例', //设置标题
  //text: null, //设置null则不显示标题
 },
 //x轴
 xAxis: {
  title: {
   text: 'X 轴 标 题'
  },
  categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'] 
 },
 //y轴
 yAxis: {
  title: { text: 'Y 轴 标 题' }, //设置Y轴标题关闭
 },
 //数据列
 series: [{
  data:[120,360,560,60,360,160,40,360,60,230,230,300]
  }] 
}; 
$(document).ready(function(){
 oChart = new Highcharts.Chart(oOptions);
 //异步添加第2条数据列
 LoadSerie_Ajax();
}); 
//异步读取数据并加载到图表
function LoadSerie_Ajax() { 
  oChart.showLoading(); 
  $.ajax({ 
   url : 'ajax/get_value.aspx',
   type : 'POST',
   dataType : 'json',
   async : false, //同步处理后面才能处理新添加的series
   contentType: "application/x-www-form-urlencoded; charset=utf-8", 
   success : function(rntData){
     var oSeries = {
     name: "第二条",
     data: rntData.rows1
    };
    oChart.addSeries(oSeries);
   }
  });
  oChart.hideLoading(); 
}

第三部分:C#代码

Response.Clear();
Response.Write("{\"rows1\":[10,20,30,40,50,200,70,100,90,200,100,60]}");
Response.End(); 
 输出的数据格式为 {"rows1":[10,20,30,40,50,200,70,100,90,200,100,60]} 
 多条的数据格式为 {"rows1":[10,20,30,40,50,200,70,100,90,200,100,60],"rows2":[10,20,30,40,50,200,70,100,90,200,100,60]}

第四部分:HTML页面代码

<div id="container" style="min-width:400px;width:1200px;height:400px;"></div>

下面给大家分享一段代码关于highcharts异步获取数据

页面异步代码

$(function () {
   var chart_validatestatics;
   $(document).ready(function () {
    var options_validatestatics = {
     chart: {
      renderTo: 'container_validatestatics',
      type: 'column'
     },
     title: {
      text: '验票分析'
     },
     subtitle: {
      text: 'tourol.cn'
     },
     xAxis: {
    },
    yAxis: {
     title: {
      text: '人数'
     }
    },
    plotOptions: {
     bar: {
      dataLabels: {
       enabled: true
      }
     }
    },
    tooltip: {
     formatter: function () {
      return '<b>' + this.x + '</b><br/>' + this.series.name + ': ' + this.y + '人';
     }
    },
    credits: {
     enabled: false
    },
    series: [{
     name: "验票用户",
     width: 3
    }]
   }
   $.get("/ajaxhandler/dataupdate.ashx?operate_type=validatestatics", function (data) {
    var xatrnames = [];
    var yvalidators = [];
    for (var i = 0; i < data.rows.length; i++) {
     xatrnames.push([
       data.rows[i].atrname
      ]);
     yvalidators.push([
       data.rows[i].atrname,
       parseInt(data.rows[i].nums)
      ]);
    }
    alert(xatrnames + yvalidators);
    options_validatestatics.xAxis.categories = xatrnames
    options_validatestatics.series[0].data = yvalidators;
    chart_validatestatics = new Highcharts.Chart(options_validatestatics);
   });
  });
 });

这里要注意的是:x轴数组定义好后,定义y轴数据的时候要把对应在x轴上的值也push到数组里,不然会造成无法显示的情况

对应的在ajaxhandler中,拼接字符串并返回即可

string json = "{\"rows\":[";
  for (int i = 0; i < datas.Rows.Count; i++)
  {
   json += "{\"atrname\":\"" + datas.Rows[i]["name"] + "\",\"nums\":\"" + datas.Rows[i]["nums"] + "\"},";
  }
  json = json.TrimEnd(',');
  json += "]}";
  context.Response.Write(json);
  context.Response.Flush();
  context.Response.End();
Javascript 相关文章推荐
用javascript动态调整iframe高度的代码
Apr 10 Javascript
javascript中万恶的function实例分析
May 25 Javascript
js中如何把字符串转化为对象、数组示例代码
Jul 17 Javascript
JS获取文本框,下拉框,单选框的值的简单实例
Feb 26 Javascript
jquery实现在光标位置插入内容的方法
Feb 05 Javascript
CSS图片响应式 垂直水平居中
Aug 14 Javascript
jquery-mobile基础属性与用法详解
Nov 23 Javascript
angular-ui-sortable实现可拖拽排序列表
Dec 28 Javascript
微信小程序 登陆流程详细介绍
Jan 17 Javascript
vue使用v-if v-show页面闪烁,div闪现的解决方法
Oct 12 Javascript
vue + typescript + video.js实现 流媒体播放 视频监控功能
Jul 07 Javascript
js实现前端界面导航栏下拉列表
Aug 27 Javascript
JavaScript阻止回车提交表单的方法
Dec 30 #Javascript
基于JavaScript代码实现微信扫一扫下载APP
Dec 30 #Javascript
分享两款带遮罩的jQuery弹出框
Dec 30 #Javascript
JavaScript小技巧整理
Dec 30 #Javascript
jQuery拖动元素并对元素进行重新排序
Dec 30 #Javascript
jQuery给元素添加样式的方法详解
Dec 30 #Javascript
Underscore源码分析
Dec 30 #Javascript
You might like
php fputcsv命令 写csv文件遇到的小问题(多维数组连接符)
2011/05/24 PHP
php对大文件进行读取操作的实现代码
2013/01/23 PHP
php根据年月获取季度的方法
2014/03/31 PHP
ThinkPHP5.0 图片上传生成缩略图实例代码说明
2018/06/20 PHP
php xhprof使用实例详解
2019/04/15 PHP
laravel 使用事件系统统计浏览量的实现
2019/10/16 PHP
PHP操作Redis常用命令的实例详解
2020/12/23 PHP
5分钟理解JavaScript中this用法分享
2013/11/09 Javascript
jQuery 文本框得失焦点的简单实例
2014/02/19 Javascript
js冒泡、捕获事件及阻止冒泡方法详细总结
2014/05/08 Javascript
原生JavaScript编写canvas版的连连看游戏
2016/05/29 Javascript
vue.js指令和组件详细介绍及实例
2017/04/06 Javascript
基于JavaScript实现表格滚动分页
2017/11/22 Javascript
通过javascript实现段落的收缩与展开
2019/06/26 Javascript
vue2路由基本用法实例分析
2020/03/06 Javascript
JavaScript enum枚举类型定义及使用方法
2020/05/15 Javascript
Bootstrap FileInput实现图片上传功能
2021/01/28 Javascript
python装饰器使用方法实例
2013/11/21 Python
Python subprocess模块功能与常见用法实例详解
2018/06/28 Python
opencv python 图片读取与显示图片窗口未响应问题的解决
2020/04/24 Python
Java ExcutorService优雅关闭方式解析
2020/05/30 Python
Python用类实现扑克牌发牌的示例代码
2020/06/01 Python
使用CSS实现阅读进度条
2017/02/27 HTML / CSS
CSS3 Columns分列式布局方法简介
2014/05/03 HTML / CSS
基于 HTML5 的 WebGL 3D 版俄罗斯方块的示例代码
2018/05/28 HTML / CSS
教师师德教育的自我评价
2013/10/31 职场文书
外贸专业求职信
2014/03/09 职场文书
如何写好自荐信
2014/04/07 职场文书
竞选学生会演讲稿
2014/04/25 职场文书
机电专业求职信
2014/06/14 职场文书
2014年度培训工作总结
2014/11/27 职场文书
班主任先进事迹材料
2014/12/17 职场文书
2015年保管员工作总结
2015/04/30 职场文书
教师节主持词开场白
2015/05/29 职场文书
高二化学教学反思
2016/02/22 职场文书
80行代码写一个Webpack插件并发布到npm
2021/05/24 Javascript