美文网首页
巧用Highcharts展示不同维度的数据

巧用Highcharts展示不同维度的数据

作者: 穿靴子跳迪斯kou的猫 | 来源:发表于2018-04-16 09:57 被阅读0次

      测试报告的展示,通常需要通过饼图,柱状图,折线图等来分析对比、占比、走势等,我们可以采用Highcharts来生成漂亮又实用的图表,本文介绍如何将不同纬度的数据整合在一张图表中。

      以App性能数据展示为例。前提,后端已经收集到测试数据,要求将不同维度的数据展示在同一个图表中,首先需要对数据进行归一化处理,具体归一化的方法不再此处详述;鼠标聚焦后展示详情,再反归一化,在详情中回归原始数据。

image

highcharts官网demo:https://www.hcharts.cn/demo/highcharts

处理如下:
1.依赖文件

 <script src="Highcharts-5.0.12/code/highcharts.js"></script>
<script src="Highcharts-5.0.12/code/highcharts-more.js"></script>

2. 自定义图表颜色
      图表样式设置,logo显示与隐藏设置属性credits:{enabled:true/false};
角标显示与隐藏设置属性 exporting:{enabled:true/false}

      自定义颜色属性colors ,多纬度数据用不同颜色展示,可以采用数组

Highcharts.setOptions({colors:['#049af0','#fedd32','#94cb61','#f9b368','#ff743c','#02df82','#64E572','#FFF263']});

3.填充自定义数据
      *series属性设置,json格式表示不同纬度的数据

series: [
        {
            name: 'CPU数据',
            data:cpuDatas
        },{
           name:xx,
          data:xx,
        }, {
            }
    ]*

4.自定义浮动框展示详情
      数据节点的详情可以在tooltip的formatter方法中扩充,例如以表格的形式,再通过this.point[x]取出当前鼠标所至节点的不同值,示例如下:

tooltip: {*
crosshairs:true,
shared:true,
formatter:function() {
var s ='
性能详情'+'';
s+='
时间:'+tmpTime+' '+this.x+'';

s +='
-------------------';

s+='
CPU:'+ parseFloat(dealData(this.point[0].y)).toFixed(2)+'%';

s+='
内存:'+ parseFloat(dealData(this.point[1].y)).toFixed(2)+'M';

s+='
流量:'+ parseFloat(dealData(this.point[2].y)).toFixed(3)+'KB';

s+='
掉帧率:'+ parseFloat(dealData(this.point[3].y)).toFixed(2)+'%';

returns;
*}
其中,this.point[x]取出的值是已经处理过的(如归一化处理),保证原数据不失真,自定义dealData方法,对数据进行反归一化处理操作
6.自定义节点的形状和大小
      为了更好的区分不同的类型的数据,可以添加属性marker设置节点的形状和大小,如下:

series: [
{
name:'CPU',
marker: {
symbol:'square' //每个数据节点设置为小正方形
},
data:formatCpu
}, {
name:'内存',
marker: {
symbol:'circle' //每个数据节点设置为小圆圈
},
data:formatMem
}]

symbol有'diamond','circle','square','triangle','triangle-down',缺失为circle。
节点的大小设定如下
plotOptions: {
spline: {
marker: {
enable:true,
radius: 1, //自定义节点的半径为1px
lineColor:'#666666',
*lineWidth: 0.5 *
*symbol:'diamond'
}
}
如果设置为通用大小,可以在plotOptions的marker中设定,如果数据类别比较多,需要区别,在series属性中设定。
按照以上步骤处理数据,就可以在一张表中展示多个维度的数据,在测试报告撰写中比较实用。

相关文章

  • 巧用Highcharts展示不同维度的数据

    测试报告的展示,通常需要通过饼图,柱状图,折线图等来分析对比、占比、走势等,我们可以采用Highcharts来生成...

  • Highcharts Highstock如何在x轴Navigat

    当前公司在使用HighCharts来做图表展示大量数据. 其中HighStock是很好的展示时间轴图表的工具. 最...

  • 机器学习数据可视化

    本文档以机器学习Titanic、iris等数据为原型,分析不同数据项,不同维度的情况下,可以展示哪些可视化图表。 ...

  • 数据分析必备!4大思维方式

    数据本身没有价值,合理的分析利用之后才能提炼有用信息。 数据分析说白了就是将特定范围的数据进行不同维度的组合,展示...

  • 绘制一张散点图

    数据:鸢尾属三个不同种的花的形态特征测量结果 目的:一张图展示出数据集4个不同维度的信息 横轴为萼片的长度 纵轴为...

  • 可视化库Highcharts-6-图形下钻

    Highcharts-6—下钻图形 本文中只讲解一个图形的制作:下钻图 下钻表示的是通过层级的方式来展示数据,比如...

  • 龙门石窟大数据项目原型设计

    龙门石窟大数据项目中我主要负责游客分析与舆情监控模块,收集汇总12个不同渠道的数据源,多维度的数据分析与展示,此篇...

  • 开发之路

    数据是按照不同维度展示给不同角色的。 系统拆分,单模块应用到微服务调用 (多个模块可以组合成一个服务,每个服务有自...

  • 在微信小程序中使用 Highcharts

    我们收到很多微信小程序开发者的反馈,表示强烈需要 Highcharts 进行数据展示。但是微信小程序不支持 DOM...

  • 在微信小程序中使用 Highcharts

    我们收到很多微信小程序开发者的反馈,表示强烈需要 Highcharts 进行数据展示。但是微信小程序不支持 DOM...

网友评论

      本文标题:巧用Highcharts展示不同维度的数据

      本文链接:https://www.haomeiwen.com/subject/xlcckftx.html