echarts统计x轴区间的数值实例代码详解


Posted in Javascript onJuly 07, 2019

有时我们需要统计自定义echarts图,统计x轴区间的y轴数量。

思路是利用echarts的自定义配置:option.series[i].type='custom'中的renderItem(params, api)函数进行处理,这里包括了两个参数:params是对应每一个dataItem的数据信息;api是可调用的方法(api.value()和api.coord())。详情可以查看官方文档。

以下是改自官方实例: https://www.echartsjs.com/examples/editor.html?c=bar-histogram ,把以下引用 ecStat.js来处理数据的部分修改成自己拼装成需要的格式

var bins = ecStat.histogram(girth);
var min = Infinity;
var max = -Infinity;
edata = echarts.util.map(bins.data, function (item, index) {
 var x0 = bins.bins[index].x0;
 var x1 = bins.bins[index].x1;
 interval = x1 - x0;
 min = Math.min(min, x0);

max = Math.max(max, x1);

return [x0, x1, item[1]];
});

原因是引用ecStat.js处理数据时,有时出现以下错误,暂时没找到解决方法。

echarts统计x轴区间的数值实例代码详解

改写后的代码显示效果如下:

echarts统计x轴区间的数值实例代码详解

<div id="main1" style="width: 1000px;height: 500px"></div>
<script type="text/javascript">
 $(function(){
  generateChart();
 });
 function generateChart(){
  var myChart1 = echarts.init(document.getElementById('main1'));
  var girth = [19, 26.4, 34, 41.4, 42.4, 42.7, 42.9, 43.1, 43.2, 43.3, 43.3, 43.3, 44.9, 45.4, 46.2, 46.7, 48, 48, 49.1, 54.2];
  //自定义拼装数据方式

 var edata = new Array();
  var scopeMin = 0;
  var scopeMax = 100;
  var interval = (scopeMax-scopeMin)/10;
  var tmin = scopeMin;
  while(tmin < scopeMax){
   var x0 = tmin; 
   var x1 = tmin+interval;
   var samplenum = 0;
   for(var i=0;i<girth.length;i++){
    if((scopeMin == x0 && girth[i] < x0) || (x0 <= girth[i] && x1 > girth[i])
     ||(scopeMin == x1 && girth[i] > x1)) {
     samplenum++;    
    }
   }
   tmin += interval;
   edata.push([x0, x1, samplenum]);
  }
  var option = {
   color: ['rgb(25, 183, 207)'],
   grid: {
    top: 80,
    containLabel: true
   },
   xAxis: [{
    type: 'value',
    min: scopeMin,
    max: scopeMax,
    interval: interval
   }],
   yAxis: [{
    type: 'value',
   }],
   series: [{
    name: 'height',
    type: 'custom',
    renderItem: renderItem,
    label: {
     normal: {
      show: true,
      position: 'top'
     }
    },
    encode: {
     x: [0, 1],
     y: 2,
     tooltip: 2,
     label: 2
    },
    // data: data
    data: edata
   }]
  };
  myChart1.setOption(option);
  window.onresize = function () {
   myChart1.resize();
  }
 }
 function renderItem(params, api) {
  var yValue = api.value(2);
  var start = api.coord([api.value(0), yValue]);
  var size = api.size([api.value(1) - api.value(0), yValue]);
  var style = api.style();
  return {
   type: 'rect',
   shape: {
    x: start[0] + 1,
    y: start[1],
    width: size[0] - 2,
    height: size[1]
   },
   style: style
  };
 }
</script>

总结

以上所述是小编给大家介绍的echarts统计x轴区间的数值实例代码详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
xml 封装与解析(javascript和C#中)
Jul 26 Javascript
模仿JQuery sortable效果 代码有错但值得看看
Nov 05 Javascript
用RadioButten或CheckBox实现div的显示与隐藏
Sep 21 Javascript
js判断是否为ie的方法小结
Jan 13 Javascript
Node.js中的缓冲与流模块详细介绍
Feb 11 Javascript
JS如何判断json是否为空
Jul 06 Javascript
jQuery图片切换动画效果
Feb 28 Javascript
详解vue-router 路由元信息
Sep 13 Javascript
轻量级JS Cookie插件js-cookie的使用方法
Mar 22 Javascript
详解用JS添加和删除class类名
Mar 25 Javascript
es6中比较有用的7个技巧小结
Jul 12 Javascript
SpringBoot+Vue 前后端合并部署的配置方法
Dec 30 Vue.js
vue + typescript + video.js实现 流媒体播放 视频监控功能
Jul 07 #Javascript
详解django模板与vue.js冲突问题
Jul 07 #Javascript
django中使用vue.js的要点总结
Jul 07 #Javascript
Vue使用lodop实现打印小结
Jul 06 #Javascript
cordova+vue+webapp使用html5获取地理位置的方法
Jul 06 #Javascript
elementui之el-tebs浏览器卡死的问题和使用报错未注册问题
Jul 06 #Javascript
vue router总结 $router和$route及router与 router与route区别
Jul 05 #Javascript
You might like
用sql命令修改数据表中的一个字段为非空(not null)的语句
2010/06/04 PHP
PHP GD库生成图像的几个函数总结
2014/11/19 PHP
php中随机函数mt_rand()与rand()性能对比分析
2014/12/01 PHP
zen_cart实现支付前生成订单的方法
2016/05/06 PHP
php  PATH_SEPARATOR判断当前服务器系统类型实例
2016/10/28 PHP
Zend Framework入门应用实例详解
2016/12/11 PHP
php常用字符串长度函数strlen()与mb_strlen()用法实例分析
2019/06/25 PHP
checkbox全选/取消全选以及checkbox遍历jQuery实现代码
2009/12/02 Javascript
怎么清空javascript数组
2013/05/11 Javascript
解析Jquery的LigerUI如何实现文件上传
2013/07/09 Javascript
点击弹出层外区域关闭弹出层jquery特效示例
2013/08/25 Javascript
nodeJS代码实现计算交社保是否合适
2015/03/09 NodeJs
js实现登陆遮罩效果的方法
2015/07/28 Javascript
全面解析Bootstrap中tooltip、popover的使用方法
2016/06/13 Javascript
基于vue2.0+vuex的日期选择组件功能实现
2017/03/13 Javascript
vue-cli 默认路由再子路由选中下的选中状态问题及解决代码
2018/09/06 Javascript
微信小程序分包加载代码实现方法详解
2019/09/23 Javascript
js实现简单的贪吃蛇游戏
2020/04/23 Javascript
详解Python网络爬虫功能的基本写法
2016/01/28 Python
Python 含参构造函数实例详解
2017/05/25 Python
利用Python模拟登录pastebin.com的实现方法
2019/07/12 Python
python PyQt5/Pyside2 按钮右击菜单实例代码
2019/08/17 Python
python+opencv实现车牌定位功能(实例代码)
2019/12/24 Python
Django 多对多字段的更新和插入数据实例
2020/03/31 Python
python基于win32api实现键盘输入
2020/12/09 Python
Html5剪切板功能的实现代码
2018/06/29 HTML / CSS
html5 svg 中元素点击事件添加方法
2013/01/16 HTML / CSS
美国五金商店:Ace Hardware
2018/03/27 全球购物
初婚未育证明样本
2014/10/24 职场文书
1000字打架检讨书
2014/11/03 职场文书
教师工作决心书
2015/02/04 职场文书
违反纪律检讨书范文
2015/05/07 职场文书
2016年离婚协议书范文
2016/03/18 职场文书
学会用Python实现滑雪小游戏,再也不用去北海道啦
2021/05/20 Python
python 命令行传参方法总结
2021/05/25 Python
MySQL8.0的WITH查询详情
2021/08/30 MySQL