vue基于v-charts封装双向条形图的实现代码
网络编程 2021-07-04 15:02www.168986.cn编程入门
这篇文章主要介绍了vue基于v-charts封装双向条形图的实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
我们先来看实现效果
以这张图来举例
通过重新封装可以实现双向条形图的显示
既可以横向比较同一天的收入支出情况
也可以竖向比较不同日期的收入/支出情况
我们先来准备数据源:
{ 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.stack string
数据堆叠,同个类目轴上系列配置相同的stack值可以堆叠放置。
也就是说,设置了这个属性,我们可以让两个条形图合并为一个
如果不考虑正负问题,堆叠即可实现狼蚁网站SEO优化这个效果
感兴趣的可以去官方看一下在线运行的演示效果
设置完这个属性我们来看一下效果
可以看到同一日期的收入支出情况已经在一行显示了
我们来解决坐标轴及图形标签值显示为负数的问题
我们可以在 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) { return Math.abs(value); } //显示的数值都取绝对值 }; return options; },
这样就可以实现我们的最终效果了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程