经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
vue可视化图表 基于Echarts封装好的v-charts简介
来源:cnblogs  作者:一笑而过1  时间:2019/3/29 9:13:34  对本文有异议

**vue可视化图表 基于Echarts封装好的v-charts**

近期公司又一个新的需求,要做一个订单和销售额统计的项目,需要用到可视化图表来更直观的展示数据。首先我想到的是Echarts,众所周知Echarts是一个应用很广的可视化图表库,用来展示统计数据更合适不过,但是偶然间发现了一个更为方便的图表库,就是我们今天要介绍的v-charts,它是基于Echarts图表库进行了一次封装,让我们可以更好更方便更简单的来展示我们的数据,首先附上他的官方介绍:点击这里

v-charts对于用户很友好,把数据封装成很好的模式,不进让我们更好的来使用它,而且他还完全支持Echarts的所有方法和属性。Echarts有的图表,v-charts都进行了封装。


下面先来一个柱状图:

现附上效果图:

 

下面是使用方法:

点击这里查看原帖

1.安装依赖

*这里需要说明,由于v-charts是基于Echarts进行封装的,所以我们在安装依赖的时候,需要把Echarts和v-charts都进行安装。*

  1. npm install echarts v-charts --save-dev

 

2.依赖安装好之后,我们直接引入v-charts即可,我们在main.js中进行引入

  1. import VCharts from 'v-charts'
  2. Vue.use(VCharts)

 



3.我们在相应的组件中直接使用就可以了,比如说柱状图是ve-histogram,我们直接写标签即可,不需要在创建一个div容器了

  1. <ve-histogram
  2. :data="chartData"
  3. :colors="chartColor"
  4. :legend-visible="true"
  5. :loading="loading"
  6. :data-empty="dataEmpty"
  7. :extend="extend"
  8. :settings="chartSettings">
  9. </ve-histogram>

 


这里介绍一下我上面用到的几个属性,
data:就是我们要绑定的数据,下面会详细介绍
colors:就是我们图表中每一项对应的颜色
legend-visible:是否显示图例
loading:是否显示loaidng
data-empty:在数据为空的时候,是否显示暂无数据
extend:就是我们自定义的Echarts的原有属性,在v-charts的一些属性满足不了我们的需求的情况下,我们可以配置extend,来直接使用Echarts的optios,来覆盖v-charts的属性。
settings:一些v-charts封装好的设置。

下面就是我们的属性配置了:
在这里需要说明一下,v-charts的无数据和loading的样式是单独的,如果需要这两个需求,我们需要引入css,如果不需要,不引入就行。

  1. import 'v-charts/lib/style.css'
  2. export default {
  3. name: 'VCharts',
  4. data () {
  5. return {
  6. chartSettings: {
  7. xAxisType: 'time',
  8. area: true,
  9. yAxisName: ['订单总数', '订单金额'],
  10. axisSite: {right: ['orderAmount']},
  11. labelMap: {'orderCount': '订单数量', 'orderAmount': '订单金额'}
  12. },
  13. chartData: {
  14. columns: ['date', 'orderCount', 'orderAmount'],
  15. rows: []
  16. },
  17. extend: {
  18. series: {
  19. symbolSize: 10,
  20. label: {
  21. normal: {
  22. show: true
  23. }
  24. }
  25. }
  26. },
  27. chartColor: ['#89dd47', '#3cabf4'],
  28. loading: false,
  29. dataEmpty: false
  30. }
  31. }
  32. created () {
  33. this.getData()
  34. }
  35. methods: {
  36. async getData () {
  37. const res = await getOrderData(})
  38. if (res.data.length === 0) {
  39. this.dataEmpty = true
  40. } else {
  41. this.chartData.rows = res.data.rows
  42. this.dataEmpty = false
  43. }
  44. console.log(res)
  45. },
  46. }
  47. }

 

上述代码中的getOrderData()方法是我调用的接口方法,如下所示:

  1. // 图表订单和金额
  2. export function getOrderData (res) {
  3. return http.post({
  4. url: base_url + '/order/getOrderData',
  5. data: res
  6. })
  7. }

 


上述的http.post方法是我封装的axios的post请求方法,篇幅有限,这里不在叙述,具体封装方法,会在其他文章进行讲解。
在这里我展示一下请求过来的data的结构

  1. 1 rows: [
  2. 2 {date: '2018-11-01', orderCount: 10, orderAmount: 1093},
  3. 3 {date: '2018-11-02', orderCount: 20, orderAmount: 2230},
  4. 4 {date: '2018-11-03', orderCount: 33, orderAmount: 3623},
  5. 5 {date: '2018-11-04', orderCount: 50, orderAmount: 6423},
  6. 6 {date: '2018-11-05', orderCount: 80, orderAmount: 8492},
  7. 7 {date: '2018-11-06', orderCount: 60, orderAmount: 6293},
  8. 8 {date: '2018-11-07', orderCount: 20, orderAmount: 2293},
  9. 9 {date: '2018-11-08', orderCount: 60, orderAmount: 6293},
  10. 10 {date: '2018-11-09', orderCount: 50, orderAmount: 5293},
  11. 11 {date: '2018-11-10', orderCount: 30, orderAmount: 3293},
  12. 12 {date: '2018-11-11', orderCount: 20, orderAmount: 2293},
  13. 13 {date: '2018-11-12', orderCount: 80, orderAmount: 8293},
  14. 14 {date: '2018-11-13', orderCount: 100, orderAmount: 10293},
  15. 15 {date: '2018-11-14', orderCount: 10, orderAmount: 1293},
  16. 16 {date: '2018-11-15', orderCount: 40, orderAmount: 4293}
  17. 17 ]

 

 

这些都完成之后,我们就能在浏览器看到一开是的截图了。
下面附上完整代码,由于异步接口无法直观的展示我们的data结构,所以我在完整代码里面用的是静态数据,方便大家更直观的查看

  1. 1 <template>
  2. 2 <ve-histogram
  3. 3 :data="chartData"
  4. 4 :colors="chartColor"
  5. 5 :legend-visible="true"
  6. 6 :loading="loading"
  7. 7 :data-empty="dataEmpty"
  8. 8 :extend="extend"
  9. 9 :settings="chartSettings">
  10. 10 </ve-histogram>
  11. 11 </template>
  12. 12 <script>
  13. 13
  14. 14 const DATA_FROM_BACKEND = {
  15. 15 rows: [
  16. 16 {date: '2018-11-01', orderCount: 10, orderAmount: 1093},
  17. 17 {date: '2018-11-02', orderCount: 20, orderAmount: 2230},
  18. 18 {date: '2018-11-03', orderCount: 33, orderAmount: 3623},
  19. 19 {date: '2018-11-04', orderCount: 50, orderAmount: 6423},
  20. 20 {date: '2018-11-05', orderCount: 80, orderAmount: 8492},
  21. 21 {date: '2018-11-06', orderCount: 60, orderAmount: 6293},
  22. 22 {date: '2018-11-07', orderCount: 20, orderAmount: 2293},
  23. 23 {date: '2018-11-08', orderCount: 60, orderAmount: 6293},
  24. 24 {date: '2018-11-09', orderCount: 50, orderAmount: 5293},
  25. 25 {date: '2018-11-10', orderCount: 30, orderAmount: 3293},
  26. 26 {date: '2018-11-11', orderCount: 20, orderAmount: 2293},
  27. 27 {date: '2018-11-12', orderCount: 80, orderAmount: 8293},
  28. 28 {date: '2018-11-13', orderCount: 100, orderAmount: 10293},
  29. 29 {date: '2018-11-14', orderCount: 10, orderAmount: 1293},
  30. 30 {date: '2018-11-15', orderCount: 40, orderAmount: 4293}
  31. 31 ]
  32. 32 };
  33. 33
  34. 34 import 'v-charts/lib/style.css'
  35. 35 export default {
  36. 36 name: 'VCharts',
  37. 37 data () {
  38. 38 return {
  39. 39 chartSettings: {
  40. 40 xAxisType: 'time',
  41. 41 area: true,
  42. 42 yAxisName: ['订单总数', '订单金额'],
  43. 43 axisSite: {right: ['orderAmount']},
  44. 44 labelMap: {'orderCount': '订单数量', 'orderAmount': '订单金额'}
  45. 45 },
  46. 46 chartData: {
  47. 47 columns: ['date', 'orderCount', 'orderAmount'],
  48. 48 rows: []
  49. 49 },
  50. 50 extend: {
  51. 51 series: {
  52. 52 symbolSize: 10,
  53. 53 label: {
  54. 54 normal: {
  55. 55 show: true
  56. 56 }
  57. 57 }
  58. 58 }
  59. 59 },
  60. 60 chartColor: ['#89dd47', '#3cabf4'],
  61. 61 loading: false,
  62. 62 dataEmpty: false
  63. 63 }
  64. 64 }
  65. 65 created () {
  66. 66 this.getData()
  67. 67 }
  68. 68 methods: {
  69. 69 async getData () {
  70. 70 const res = await getOrderData(})
  71. 71 if (res.data.length === 0) {
  72. 72 this.dataEmpty = true
  73. 73 } else {
  74. 74 this.chartData.rows = DATA_FROM_BACKEND.rows // 注意这里应该是接口给返回回来的数据,为了方便展示data结构,我这里用的是静态数据
  75. 75 this.dataEmpty = false
  76. 76 }
  77. 77 console.log(res)
  78. 78 },
  79. 79 }
  80. 80 }
  81. 81 </script>

 

以上就是v-charts的基本用法了,上面用的是柱状图,其他例如:折线图,饼状图等等都是这样的用法,区别就是标签不一样

  1. 1 //折线图
  2. 2 <ve-line :data="chartData"></ve-line>
  3. 3 //饼状图
  4. 4 <ve-pie :data="chartData"></ve-pie>
View Code

 



等等这里不在一一赘述,需要的直接去看v-charts官网介绍即可。
如果有我没说明白的地方,欢迎大家给我留言或者私信。

原文链接:http://www.cnblogs.com/hyl1991/p/10613692.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号