vue基于v-charts封装双向条形图的实现代码
我们先来看实现效果
以这张图来举例
通过重新封装可以实现双向条形图的显示
既可以横向比较同一天的收入支出情况
也可以竖向比较不同日期的收入/支出情况
我们先来准备数据源:
{ columns:["日期","收入","支出"], rows:[ { 日期:"8/7", 收入:-233, 支出:120 }, { 日期:"8/5", 收入:-322, 支出:450 }, { 日期:"7/4", 收入:-432, 支出:430 }, { 日期:"10/4", 收入:-233, 支出:210 } ] };
注意这里一定要把其中一项的值设置为负数,否则无法显示到左边一栏
设置完数据我们可以先看一眼效果:
那如何实现同一维度的两个指标在同一行显示?
我们在配置属性中加上这么一个属性
"stack"
this.chartSettings={ stack:{ xxx:[`收入`,`支出`] } };
查看官方文档,我们来理解一下这个属性
series[i]-bar.stackstring
数据堆叠,同个类目轴上系列配置相同的stack值可以堆叠放置。
也就是说,设置了这个属性,我们可以让两个条形图合并为一个
如果不考虑正负问题,堆叠即可实现下面这个效果
https://www.echartsjs.com/examples/zh/editor.html?c=bar-negative
设置完这个属性我们来看一下效果
可以看到同一日期的收入支出情况已经在一行显示了
最后我们来解决坐标轴及图形标签值显示为负数的问题
我们可以在chartsetting属性中修改label的formatter属性
自定义标签的文字
根据我们的需求,通过Math.abs()的方法,以绝对值的形式显示
this.chartSettings={ label:{ normal:{ show:true, formatter:params=>{ return`${params.seriesName}:${Math.abs(params.value)}`; } } } };
坐标轴数值修改也是一个道理
afterConfig(options){ options.xAxis[0].axisLabel={ formatter:function(value){ returnMath.abs(value); }//显示的数值都取绝对值 }; returnoptions; },
这样就可以实现我们的最终效果了
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。