highcharts.js数据绑定方式代码实例


Posted in Javascript onNovember 13, 2019

这篇文章主要介绍了highcharts.js数据绑定方式代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一,我们先来看看异步加载数据的写法(这是使用MVC的例子)

1 js写法

<script src="~/Scripts/jquery-2.1.4.min.js"></script>
<script src="~/Scripts/highcharts.js"></script>

<div id="chart"></div>
<script type="text/javascript">


  //定义一个Highcharts的变量,初始值为null
  var highCharts = null;

  //定义highCharts的布局环境
  //布局环境组成:X轴、Y轴、数据显示、图标标题
  var oOptions = {
    chart: {
      renderTo: 'chart', //设置显示的页面块
      type: 'column'  //设置显示的方式
    },
    title: {
      text: ''   //设置null则不显示标题
    },
    plotOptions: {
      column: {
        pointPadding: 0,
        borderWidth: 1,
        groupPadding: 0,
        shadow: false
      }
    },
    xAxis: {
      tickWidth: 0,
      //labels: {
      //  enabled: false  //禁止X轴的标题显示
      //},
      type: 'category',
      categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
    },
    yAxis: {
      title: {
        text: ''
      },
      //labels: {
      //  enabled: false //禁止Y轴的标题显示
      //},
    },
    legend: {
      enabled: false
    },
    credits: {
      enabled: false
    },
    tooltip: {
      formatter: function () {
        return '<span>' + this.series.name + '</span>: <b>' + this.y + '</b>'+ '<span>分数范围</span>: <b>' + (this.x + 10) * 10 + "-" + (this.x + 11) * 10 + '</b>'
      },
    }
  };


  $(function () {
    highCharts = new Highcharts.Chart(oOptions);
    highCharts.showLoading();
    $.ajax({
      url: '/home/getJosn2',
      type: 'POST',
      success: function (Data) {
        Data = eval("(" + Data + ")");
        var Series = {
          name: "人数",
          data: Data.rows,
          color: '#ddd'
        };
        highCharts.addSeries(Series);
      }
    });
    highCharts.hideLoading();
  });
</script>

2 C#后台代码(MVC)

[HttpPost]
    public JsonResult getJosn2()
    {
      return Json("{\"rows\":[120, 360, 560, 60, 360, 160, 40, 360, { y: 150, color: '#45a9f4' }, 60, 230, 230, 300, 60, 230, 230, 300, 300]}");
    }

看我返回的json这个{ y: 150, color: '#45a9f4' }, 是什么效果呢?如下图,高亮的那条

highcharts.js数据绑定方式代码实例

二,有两种数据绑定的方法,这里使用固定数据来展示例子

第一种:

<script src="~/Scripts/jquery-2.1.4.min.js"></script>
<script src="~/Scripts/highcharts.js"></script>

<div id="chart"></div>
<script type="text/javascript">
  $(function () {
    $('#chart').highcharts({
      chart: {
        type: 'column'
      },
      title: {
        text: ''
      },
      plotOptions: {
        column: {
          pointPadding: 0,
          borderWidth: 1,
          groupPadding: 0,
          shadow: false
        }
      },
      xAxis: {
        tickWidth: 0,
        //labels: {
        //  enabled: false
        //},
        type: 'category'
      },
      yAxis: {
        title: {
          text: ''
        },
        //labels: {
        //  enabled: false
        //}
      },
      legend: {
        enabled: false
      },
      credits: {
        enabled: false
      },
      tooltip: {
        formatter: function () {
          return '<span>' + this.series.name + '</span>: <b>' + this.y + '</b>'
        },
      },
      series: [{
        name: '人数',
        data: [
          ['Jan', 50],
          ['Feb', 60],
          ['Mar', 70],
          {
            name: "Apr",
            y: 150,
            color: "#45a9f4"
          },
          ['May', 140],
          
        ],
        color: '#ddd'
      }]
    });
  });
</script>

我们可以同时在series给X赋名字和值的一个json集合

第二种:

<script src="~/Scripts/jquery-2.1.4.min.js"></script>
<script src="~/Scripts/highcharts.js"></script>

<div id="chart"></div>
<script type="text/javascript">
  $(function () {
    $('#chart').highcharts({
      chart: {
        type: 'column'
      },
      title: {
        text: ''
      },
      plotOptions: {
        column: {
          pointPadding: 0,
          borderWidth: 1,
          groupPadding: 0,
          shadow: false
        }
      },
      xAxis: {
        tickWidth: 0,
        //labels: {
        //  enabled: false
        //},
        type: 'category',
        categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May']
      },
      yAxis: {
        title: {
          text: ''
        },
        //labels: {
        //  enabled: false
        //}
      },
      legend: {
        enabled: false
      },
      credits: {
        enabled: false
      },
      tooltip: {
        formatter: function () {
          return '<span>' + this.series.name + '</span>: <b>' + this.y + '</b>'
        },
      },
      series: [{
        name: '人数',
        data: [120, 360, { y: 150, color: "#45a9f4" }, 560, 60],
        color: '#ddd'
      }]
    });
  });
</script>

我们X轴的标题和值也可以分开赋值,如上

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js中function()使用方法
Dec 24 Javascript
jQuery分别获取选中的复选框值的示例
Jun 17 Javascript
JS实现网页顶部向下滑出的全国城市切换导航效果
Aug 22 Javascript
Bootstarp风格的toggle效果分享
Feb 23 Javascript
使用RequireJS库加载JavaScript模块的实例教程
Jun 06 Javascript
Javascript 使用ajax与C#获取文件大小实例详解
Jan 13 Javascript
vue学习笔记之vue1.0和vue2.0的区别介绍
May 17 Javascript
详解各版本React路由的跳转的方法
May 10 Javascript
JavaScript设计模式之原型模式分析【ES5与ES6】
Jul 26 Javascript
Element UI框架中巧用树选择器的实现
Dec 12 Javascript
Vue v-text指令简单使用方法示例
Sep 19 Javascript
JavaScript实现tab栏切换效果
Mar 16 Javascript
vue prop属性传值与传引用示例
Nov 13 #Javascript
Vue 使用Props属性实现父子组件的动态传值详解
Nov 13 #Javascript
浅谈vue 锚点指令v-anchor的使用
Nov 13 #Javascript
Jquery异步上传文件代码实例
Nov 13 #jQuery
解决ele ui 表格表头太长问题的实现
Nov 13 #Javascript
vue 实现 rem 布局或vw 布局的方法
Nov 13 #Javascript
详解如何在Javascript和Sass之间共享变量
Nov 13 #Javascript
You might like
德劲1107的电路分析与打磨
2021/03/02 无线电
php中模拟POST传递数据的两种方法分享
2011/09/16 PHP
PHP spl_autoload_register实现自动加载研究
2011/12/06 PHP
浅谈web上存漏洞及原理分析、防范方法(文件名检测漏洞)
2013/06/29 PHP
PHP中常见的缓存技术实例分析
2015/09/23 PHP
thinkphp实现图片上传功能
2016/01/13 PHP
PHP使用curl制作简易百度搜索
2016/11/03 PHP
zend框架实现支持sql server的操作方法
2016/12/08 PHP
laravel通过创建自定义artisan make命令来新建类文件详解
2017/08/17 PHP
PHP命令空间namespace及use的用法小结
2017/11/27 PHP
PHP 应用容器化以及部署方法
2018/02/12 PHP
javascript使用isNaN()函数判断变量是否为数字
2013/09/21 Javascript
node.js中的fs.lstatSync方法使用说明
2014/12/16 Javascript
JavaScript文档碎片操作实例分析
2015/12/12 Javascript
CSS中position属性之fixed实现div居中
2015/12/14 Javascript
vuejs+element-ui+laravel5.4上传文件的示例代码
2017/08/12 Javascript
node前端开发模板引擎Jade的入门
2018/05/11 Javascript
微信公众平台 客服接口发消息的实现代码(Java接口开发)
2019/04/17 Javascript
[03:06]2018年度CS GO最具人气解说-完美盛典
2018/12/16 DOTA
python中List的sort方法指南
2014/09/01 Python
使用Python脚本将绝对url替换为相对url的教程
2015/04/24 Python
Python判断列表是否已排序的各种方法及其性能分析
2016/06/20 Python
python程序 线程队列queue使用方法解析
2019/09/23 Python
Python 3 使用Pillow生成漂亮的分形树图片
2019/12/24 Python
python连接PostgreSQL过程解析
2020/02/09 Python
如何让python的运行速度得到提升
2020/07/08 Python
宝塔面板出现“open_basedir restriction in effect. ”的解决方法
2021/03/14 PHP
纯css3无js实现的Android Logo(有简单动画)
2013/01/21 HTML / CSS
html5中去掉input type date默认样式的方法
2018/09/06 HTML / CSS
全球速卖通法国在线交易平台:AliExpress法国
2017/07/07 全球购物
体育老师的教学自我评价分享
2013/11/19 职场文书
生日派对邀请函
2014/01/13 职场文书
《玩具柜台前的孩子》教学反思
2014/02/13 职场文书
市场总监岗位职责
2015/02/11 职场文书
大学学生会主席竞选稿
2015/11/19 职场文书
“鬼灭之刃”热度不减,其成功背后的原因是什么?
2022/03/22 日漫