Vue+Antv F2实现混合图表

本文实例为大家分享了Vue+Antv F2实现混合图表的具体代码,供大家参考,具体内容如下

一、npm安装

npm install @antv/f2 --save复制代码

二、在main.js中引入

import F2 from '@antv/f2'
 Vue.prototype.$F2= F2;

三、在vue页面组件中创建canvas

<template>
  <div id="app">
     <canvas id="caseChart" style="width: 100%;height: 230px;"></canvas>
  </div>
</template>

四、在data中声明数据源

data(){
   return{
     casechart:null,
     // 混合图数据(s_Date为图形底部时间  Total为柱状图数据  addTotal为折线图数据)
    chartsData:[{Total: 0, s_Date: "2020-12", dataType: "patentNum", addTotal: 0},
                {Total: 0, s_Date: "2021-01", dataType: "patentNum", addTotal: 0},
                {Total: 0, s_Date: "2021-02", dataType: "patentNum", addTotal: 0},
                {Total: 8, s_Date: "2021-03", dataType: "patentNum", addTotal: 8},
                {Total: 9, s_Date: "2021-04", dataType: "patentNum", addTotal: 17},
                {Total: 3, s_Date: "2021-05", dataType: "patentNum", addTotal: 20},
                {Total: 0, s_Date: "2021-06", dataType: "patentNum", addTotal: 20}]  
       // 图例(marker为图例样式)    
       legendItems:[{
         name: '委案量',
         marker: 'square',
         fill: 'rgb(41,141,248)'
       }, {
         name: '累计委案量',
         marker: function marker(x, y, r, ctx) {
           ctx.lineWidth = 1;
           ctx.strokeStyle = ctx.fillStyle;
           ctx.moveTo(x - r - 3, y);
           ctx.lineTo(x + r + 3, y);
           ctx.stroke();
           ctx.arc(x, y, r, 0, Math.PI * 2, false);
           ctx.fill();
         },
         fill: 'rgb(194,53,49)'
       }]  
   }
}             

五、图表渲染方法

caseChart(){
  var _this = this
  // 创建 Chart 对象
  _this.casechart = new _this.$F2.Chart({
    id: 'caseChart',
    pixelRatio: window.devicePixelRatio // 指定分辨率
  });

  // 载入数据源
  _this.casechart.source(_this.chartsData,{
    Total: {
      alias: '委案量'
    },
    addTotal: {
      alias: '累计委案量'
    }
  });
  
  // 自定义图例内容以及交互行为
  _this.casechart.legend({
    custom: true,
    items: _this.legendItems,
    align: 'center',
    onClick: function onClick(ev) {}
  }); 
  
  // Tooltip样式配置
  _this.casechart.tooltip({
    showCrosshairs: true,
    custom: true,
    onChange: function onChange(obj) {
      const legend = _this.casechart.get('legendController').legends.top[0];
      const tooltipItems = obj.items;
      const legendItems = legend.items;
      const map = {};
      legendItems.forEach(function(item) {
         map[item.name] = item;
      });
      tooltipItems.forEach(function(item) {
        const name = item.name;
        const value = item.value;
        if (map[name]) {
          map[name].value = value;
        }
      });
    },
    onHide: function onHide() {
      const legend = _this.casechart.get('legendController').legends.top[0];
      legend.setItems(_this.casechart.getLegendItems().country);
    }
  });      

  _this.casechart.interval().position('s_Date*Total').color('rgb(41,141,248)');  // 柱状图颜色
  _this.casechart.line().position('s_Date*addTotal').color('rgb(194,53,49)');    // 折线图颜色
  _this.casechart.point().position('s_Date*addTotal').style({                    // 折线点样式 
      fill: 'white',
      stroke: 'red',
      lineWidth: 1
    });

  _this.casechart.render();  //渲染图表
},   

六、mounted中调用

mounted() {
    var v = this;
    this.$nextTick(() => {
      v.caseChart();
    });   
  },

样式

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 在vue中使用G2图表的示例代码

    G2笔记 G2是蚂蚁金服的一套开源图表插件,因项目需要研究了一下,相比Echarts来说,G2文档比较难懂,网上也没有太多示例,所以在这里记录一些使用G2遇到的问题. 官方推荐在vue项目中使用Viser,它对G2进行了封装,使用起来可能更方便,又研究了一个Viser,结果Viser整个只对viser-react如何使用进行了介绍,对viser-vue一笔带过,官网是这么介绍的: 我们以 viser-react 举例写一个 chore 图为例,viser-vue 和 viser-ng 的用法类似

  • 在vue项目中引入highcharts图表的方法(详解)

    npm进行highchars的导入,导入完成后就可以进行highchars的可视化组件开发了 npm install highcharts --save 1.components目录下新建一个chart.vue组件 <template> <div class="x-bar"> <div :id="id" :option="option"></div> </div> </templa

  • 详解Vue2+Echarts实现多种图表数据可视化Dashboard(附源码)

    数据可视化 将数据通过图表的形式展现出来将大大的提升可读性和阅读效率 本例包含柱状图.折线图.散点图.热力图.复杂柱状图.预览面板等 技术栈 vue2.x vuex 存储公共变量,如色值等 vue-router 路由 element-ui 饿了么基于vue2开发组件库,本例使用了其中的datePicker echarts 一款丰富的图表库 webpack.ES6.Babel.Stylus... 项目截图 开发 组件化 本项目完全采用组件化的思想进行开发.使用vue-router作为路由,每个页面

  • vue.js+Echarts开发图表放大缩小功能实例

    最近使用echarts来开发某系统的图表功能,先申明我以前用的ext.js,ext.js对图表有自己的一套组件,用起来也很方便.但是由于ext.js过于臃肿,公司决定使用echarts来开发图表功能.当我们使用的时候才悲催的发现,echart绘制之后,不能随着容器div的大小而变化.而我们所开发的图表是需要有放大缩小功能,于是在网上找了很久,也没有找到合适的答案,大部分是通过监听窗口大小改变事件来设置,然而并不是我们所需要的.于是自己用了一点点时间,了解了为何echarts不能重新渲染,原来是在

  • vue使用echarts图表的详细方法

    本文为大家分享了vue使用echarts图表的方法,供大家参考,具体内容如下 该示例使用 vue-cli  脚手架搭建 安装echarts依赖 npm install echarts -S 或者使用国内的淘宝镜像: 安装 npm install -g cnpm --registry=https://registry.npm.taobao.org 使用 cnpm install echarts -S 创建图表 全局引入 main.js // 引入echarts import echarts fro

  • vue+echarts实现动态绘制图表及异步加载数据的方法

    前言 背景:vue写的后台管理,需要将表格数据绘制成图表(折线图,柱状图),图表数据都是通过接口请求回来的. 安装 cnpm install echarts --s   (我这里用了淘宝镜像,不知道同学自行百度) 实例化   在已有的项目中下载好了echarts 之后,可以打开官方文档,但是我觉得官方文档对于实例化介绍的不够清晰,这也是我为什么在这么多的文章中还要写的原因,前辈写的太模糊了,我决定好好给后来人,需要在项目中引用图表的人,一些实用,快捷的东西. 官方文档:http://echart

  • 在vue中添加Echarts图表的基本使用教程

    前言 我们在项目中经常需要使用一些折线图.柱状图.饼状图等等,之前使用过heightCharts,后来觉得这货不开源,只是做展示的话又点浪费时间,于是看了下eCharts,于是在vue-cli搭建的项目中添加了eCharts,下面是具体步骤和自己的一些学习笔记,参照于Echarts3官网 现在的前端一般需要完成将大量的数据,实现可视化.现在是大数据和云计算的时代,所以数据可视化逐渐变成一种趋势.而ECharts和d3.js则是可视化的成熟框架.对于制作的图表可以说是满足你的创造力. 两者相比,D

  • Vue+ Antv F2实现层叠柱状图

    本文实例为大家分享了Vue+ Antv F2实现层叠柱状图的具体代码,供大家参考,具体内容如下 一. 创建canvas标签 <canvas id="caseChart" style="width: 100%;height: 230px;"></canvas> 二. 编写图表绘制代码 methods:{         //获取专利案件Chart图标信息         getCaseChartData(){             var _

  • 在Vue 中实现循环渲染多个相同echarts图表

    在开发过程中我们常常需要,在一个页面中使用相同的图表来展示同级别的多个事物(如:同级别的多个不同id的仓库.同级别的多个不同id的设备等). 上图效果实现代码: <template> <div class="projectCost"> <div class="container"> <div class="wrapper" v-for="(item,index) in list" :k

  • vue-cli项目中使用echarts图表实例

    我们在项目中经常需要使用一些折线图.柱状图.饼状图等等,之前使用过heightCharts,后来觉得这货不开源,只是做展示的话又点浪费时间,于是看了下eCharts,于是在vue-cli搭建的项目中添加了eCharts,下面是具体步骤和自己的一些学习笔记,参照于Echarts3官网 现在的前端一般需要完成将大量的数据,实现可视化.现在是大数据和云计算的时代,所以数据可视化逐渐变成一种趋势.而ECharts和d3.js则是可视化的成熟框架.对于制作的图表可以说是满足你的创造力. 两者相比,D3 它

随机推荐