首页 > 其他分享 >echarts动态排序柱状图实现

echarts动态排序柱状图实现

时间:2023-10-25 11:48:10浏览次数:30  
标签:show color true 柱状图 import 排序 lineStyle echarts

<template>
  <div id="pubTaxesFsz" style="height: 100%; width: 100%"></div>
</template>

<script lang="ts" setup name="PubTaxesFsz">
import * as echarts from 'echarts/core';
import { LabelLayout, UniversalTransition } from 'echarts/features';
import {
  GridComponent,
  LegendComponent,
  TitleComponent,
  ToolboxComponent,
  TooltipComponent,
  DatasetComponent,
  TransformComponent
} from 'echarts/components';
import { BarChart, LineChart } from 'echarts/charts';
import { SVGRenderer } from 'echarts/renderers';
import { onMounted } from 'vue';

echarts.use([
  TitleComponent,
  ToolboxComponent,
  TooltipComponent,
  GridComponent,
  LegendComponent,
  DatasetComponent,
  TransformComponent,
  BarChart,
  LineChart,
  LabelLayout,
  UniversalTransition,
  SVGRenderer
]);

let monitorContainer: HTMLElement;
// let monitorChart: echarts.ECharts;
onMounted(() => {
  monitorContainer = document.getElementById('pubTaxesFsz');
  const monitorChart = echarts.init(monitorContainer);

  const myColors = {
    国内增值税: '#ce83f1',
    企业所得税: '#66e7ed',
    个人所得税: '#4bf26d',
    城镇土地使用税: '#d3d90b',
    城市维护建设税: '#7683f8'
  };
  const data = [
    ['国内增值税', '6月', 11.3],
    ['国内增值税', '7月', 12.3],
    ['国内增值税', '8月', 13.3],
    ['国内增值税', '9月', 16.3],
    ['企业所得税', '6月', 15.1],
    ['企业所得税', '7月', 18.1],
    ['企业所得税', '8月', 12.1],
    ['企业所得税', '9月', 18.1],
    ['个人所得税', '6月', 10.4],
    ['个人所得税', '7月', 13.4],
    ['个人所得税', '8月', 18.4],
    ['个人所得税', '9月', 28.4],
    ['城镇土地使用税', '6月', 5.4],
    ['城镇土地使用税', '7月', 3.4],
    ['城镇土地使用税', '8月', 8.4],
    ['城镇土地使用税', '9月', 9.4],
    ['城市维护建设税', '6月', 17.4],
    ['城市维护建设税', '7月', 22.4],
    ['城市维护建设税', '8月', 36.4],
    ['城市维护建设税', '9月', 46.4]
  ];
  const gqxsrOption = {
    grid: {
      top: 40,
      bottom: 30,
      left: 110,
      right: 50
    },
    // legend: {
    //   show: true,
    //   textStyle: {
    //     color: '#FFF'
    //   }
    // },
    tooltip: {
      transitionDuration: 0, // 防止宽度溢出外层div
      trigger: 'axis'
    },
    dataset: [
      {
        source: data.filter(function (d) {
          return d[1] === '6月';
        })
      }
    ],
    xAxis: {
      name: '金额',
      max: 'dataMax',
      // axisLabel: {
      //   textStyle: {
      //     show: true,
      //     fontFamily: '微软雅黑',
      //     color: '#FFFFFF',
      //     fontSize: '12',
      //     fontWeight: 'bolder'
      //   }
      // },
      axisLine: {
        // x轴线
        show: true,
        lineStyle: {
          // 属性lineStyle控制线条样式
          color: '#FFFFFF'
        }
      },
      axisTick: {
        // x轴刻度线
        show: true,
        lineStyle: {
          // 属性lineStyle控制线条样式
          color: '#FFFFFF'
        }
      },
      splitLine: {
        // 网格线
        show: true,
        lineStyle: {
          // 属性lineStyle控制线条样式
          type: 'dashed',
          color: 'rgba(255,255,255,0.39)'
        }
      }
    },
    yAxis: {
      name: '税种',
      nameLocation: 'start',
      type: 'category',
      inverse: true, // 表示 Y 轴从下往上是从小到大的排列
      // max: 4,//显示前n+1条,不加默认显示全部的
      axisLabel: {
        // y轴下刻度标签相关样式
        show: true,
        fontSize: 12,
        color: '#ffffff'
      },
      axisLine: {
        // 轴线
        show: true,
        lineStyle: {
          color: '#FFF'
        }
      },
      axisTick: {
        // y轴刻度线
        show: true,
        alignWithLabel: true,
        lineStyle: {
          // 属性lineStyle控制线条样式
          color: '#FFFFFF'
        }
      },
      splitLine: {
        // 网格线
        show: false,
        lineStyle: {
          // 属性lineStyle控制线条样式
          type: 'dashed',
          color: '#FFFFFF'
        }
      },
      animationDuration: 300,
      animationDurationUpdate: 300
    },
    series: [
      {
        realtimeSort: true, // 表示开启该系列的动态排序效果
        // seriesLayoutBy: 'column',
        type: 'bar',
        itemStyle: {
          color(param) {
            return myColors[param.value.item] || '#5470c6';
          }
        },
        encode: {
          // tooltip: ['item', 'zzl'],
          x: [2], // 表示维度 3、1、5 映射到 x 轴。
          y: [0] // 表示维度 2 映射到 y 轴。
        },
        label: {
          show: true,
          valueAnimation: true, // 开启标签动画,存在bug或冲突,目前无效,且开启会导致标签不显示
          position: 'right',
          color: '#ffffff'
        }
      }
    ],
    // Disable init animation.
    animation: true,
    animationDuration: 3000, // 设为 0,表示第一份数据不需要从 0 开始动画(如果希望从 0 开始则设为和 animationDurationUpdate 相同的值)
    animationDurationUpdate: 3000, // 建议设为 3000 表示每次更新动画时长,这一数值应与调用 setOption 改变数据的频率相同
    // animationEasing: 'linear',
    // animationEasingUpdate: 'linear',
    graphic: {
      // 图形元素,可悬浮,用于做水印等
      elements: [
        {
          type: 'text',
          right: 80,
          bottom: 60,
          style: {
            text: '6月',
            font: 'bolder 80px monospace',
            fill: 'rgba(255,255,255,0.66)'
          },
          z: 100
        }
      ]
    }
  };
  monitorChart.setOption(gqxsrOption);

  for (let i = 6; i < 10; ++i) {
    (function (i) {
      setTimeout(function () {
        console.log('===setTimeout===i==', i);
        updateYear(i);
      }, (i - 6) * 3000);
    })(i);
  }

  function updateYear(year) {
    const source = data.filter(function (d) {
      return d[1] === `${year}月`;
    });
    gqxsrOption.dataset[0].source = source;
    gqxsrOption.graphic.elements[0].style.text = `${year}月`;
    monitorChart.setOption(gqxsrOption);
  }
});
</script>

 

标签:show,color,true,柱状图,import,排序,lineStyle,echarts
From: https://www.cnblogs.com/dirgo/p/17786754.html

相关文章

  • 面试必刷TOP101:12、单链表的排序
    一、题目publicclassSolution{/***代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可***@paramheadListNode类theheadnode*@returnListNode类*/publicListNodesortInList(ListNodehead){......
  • ECharts
    ECharts简介ECharts是使用JavaScript实现的一个开源可视化库.Echarts的引入通过官网下载echarts的js文件通过npm或者cnpm下载,下载后这样使用:varecharts=request('echarts');ECharts的基本使用步骤一:下载并引入ECharts.js文件------->图表依赖于这个js文件步骤二:......
  • 分区函数 Partition By 与 row_number() 的用法 & 排序rank()的用法详解(获取分组(分
    partitionby关键字是分析性函数的一部分,它和聚合函数不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录,partitionby用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组,分区函数一般与排名函数一起使用。准备测试数据:createtable......
  • Python 利用pandas 和 matplotlib绘制柱状图
    当你需要展示数据时,图表是一个非常有用的工具。Python中的pandas和matplotlib库提供了丰富的功能,可以帮助你轻松地绘制各种类型的图表。本文将介绍如何使用这两个库,绘制一个店铺销售数量的柱状图,并添加各种元素,如数据标签、图例、网格线等。准备工作在开始之前,你需要安装p......
  • 浅谈排序网络与并行排序算法
    对于普通的基于比较排序我们拥有一个复杂度下界\(O(n\logn)\),然而如果我们允许并行计算的话,将得到一些复杂度更优秀的计算方法。听到并行这个词许多人就会认为你有几个线程复杂度就除以几,所以线程堆得越多越好。但许多的算法问题都必须要满足你必须要算完A才能去计算B,比如对......
  • C++桶排序算法的应用:存在重复元素 III
    题目给你一个整数数组nums和两个整数indexDiff和valueDiff。找出满足下述条件的下标对(i,j):i!=j,abs(i-j)<=indexDiffabs(nums[i]-nums[j])<=valueDiff如果存在,返回true;否则,返回false。示例1:输入:nums=[1,2,3,1],indexDiff=3,valueDiff=0输出......
  • Java List 排序的2种方法
    1. 利用Collections类的java.util.Collections.sort(java.util.List,java.util.Comparator)方法,自定义比较器对象对指定对象进行排序对学生对象按照其分数(降序)进行排序,当分数相同时按学号(从小到大)排序,代码如下:Student类classStudent{ privateintid; privateStringname......
  • 记录EF 排序配上自定义的比较器
    记录EF排序配上自定义的比较器前言要求页面文件显示的时候能够按照序号去排序要求如下:数据库有一个列存放文件名,如:1.1文件1.2文件1.1.1文件1.1.11文件1.0.txt1.1.2(文件).pdf现在需要实现查询的时候按照这个列排序,并且是按照序号排序。查询的时候是按层级查询的,每次查......
  • Oracle中通过组内排序实现行转列(三)
    1纵表平铺1.1原数据 1.2平铺结果:每个班级按照年龄从小到大平铺为一行select*from(selectrt.class,row_number()over(partitionbyrt.classorderbyrt.age)row_num,rt.sno,rt.snamefromrank_tes......
  • Spring Data JPA : 查-分页排序
    1.分页查询 pageNumber是从0开始,pageNumber=0,pageSize=3就是获取前3条参考创建分页Pageable变量创建Pageable对象,再查询importjava.util.List;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.data.domain.Page;import......