当前位置: 首页 > news >正文

ECharts系列: Vue 中使用 ECharts 折线图时,怎么配置来实现默认隐藏某些图例,并在用户点击图例时显示或隐藏对应的数据系列

目录

背景介绍

想要实现样式

代码说明

关键点解析

(1) 默认隐藏“日常巡检”

(2) 图例点击事件

(3) 动态更新图表

(4) 数据结构

运行结果

(1) 默认状态

(2) 点击图例

扩展功能

(1) 自定义初始隐藏多个图例

(2) 添加动画效果

(3) 响应式布局

总结

参考


背景介绍

在最近一个大屏中,有一个需求,想默认隐藏“日常巡检”图例,在用户点击图例的时候显示或隐藏对应的图例;

想要实现样式

在大屏中,产品想让默认不显示“日常巡检”,鼠标移入时tooltip中不显示“日常巡检”的

再点击图例“日常巡检”,显示“日常巡检”的值,tooltip中显示“日常巡检”的

代码说明

在查找了echart官网配置后

了解到可以通过配置 legendseriesshow 属性来实现默认隐藏某些图例(如“日常巡检”),并在用户点击图例时显示或隐藏对应的数据系列。以下是完整的实现代码和详细解析。

<template>
  <div ref="chart" style="width: 100%; height: 500px;"></div>
</template>

<script>
import * as echarts from 'echarts';
import { onMounted, ref } from 'vue';

export default {
  setup() {
    const chart = ref(null); // 用于挂载图表的 DOM 元素

    const initChart = () => {
      // 初始化 ECharts 实例
      const myChart = echarts.init(chart.value);

      // 配置项
      const option = {
        title: {
          text: '折线图',
          left: 'center',
        },
        tooltip: {
          trigger: 'axis',
        },
        legend: {
          data: ['维修养护', '日常巡检', '应急响应'], // 图例名称
        },
        xAxis: {
          type: 'category',
          data: ['00:00', '04:00', '08:00', '12:00', '16:00', '20:00'], // 时间轴数据
        },
        yAxis: {
          type: 'value',
        },
        series: [
          {
            name: '维修养护',
            type: 'line',
            data: [1.2, 1.5, 1.3, 1.7, 1.6, 1.8], 
          },
          {
            name: '日常巡检',
            type: 'line',
            data: [0.5, 0.6, 0.7, 0.8, 0.9, 1.0], 
            show: false, // 默认不显示
          },
          {
            name: '应急响应',
            type: 'line',
            data: [10, 15, 20, 25, 30, 35], 
          },
        ],
      };

      // 设置初始配置
      myChart.setOption(option);

      // 监听图例点击事件
      myChart.on('legendselectchanged', (event) => {
        const selected = event.selected; // 获取当前图例选中状态
        const newOption = {
          series: option.series.map((serie) => {
            return {
              ...serie,
              show: selected[serie.name], // 根据图例选中状态动态设置 show 属性
            };
          }),
        };
        myChart.setOption(newOption); // 更新图表配置
      });
    };

    // 在组件挂载时初始化图表
    onMounted(() => {
      initChart();
    });

    return {
      chart,
    };
  },
};
</script>

<style scoped>
.chart-container {
  width: 100%;
  height: 500px;
}
</style>

关键点解析

(1) 默认隐藏“日常巡检”
  • 在 series 配置中,为“日常巡检”数据系列添加 show: false,使其默认不显示。
  • 注意:ECharts 并没有原生支持 show 属性,因此需要通过监听图例点击事件动态控制显示/隐藏。
(2) 图例点击事件
  • 使用 myChart.on('legendselectchanged', callback) 监听图例点击事件。
  • event.selected 是一个对象,记录了每个图例的选中状态(true 表示选中,false 表示未选中)。
  • 根据 event.selected 动态更新 series 的 show 属性,并调用 setOption 刷新图表。
(3) 动态更新图表
  • 在 legendselectchanged 回调中,通过 option.series.map() 遍历所有数据系列,并根据 selected 状态动态设置 show 属性。
  • 最后调用 myChart.setOption(newOption) 更新图表。
(4) 数据结构
  • xAxis.data 定义了时间轴数据。
  • series 定义了多个数据系列(如'维修养护', '日常巡检', '应急响应')。
  • 每个数据系列的 data 是对应的数值数组。

运行结果

(1) 默认状态
  • 图表中默认显示“维修养护”和“应急响应”的线或柱,“日常巡检”的折线被隐藏。
(2) 点击图例
  • 点击“日常巡检”图例时,显示“日常巡检”的折线。
  • 再次点击“日常巡检”图例时,隐藏“日常巡检”的折线。

扩展功能

(1) 自定义初始隐藏多个图例

如果需要默认隐藏多个图例,可以在 series 中为对应的系列添加 show: false。例如:

series: [
  {
    name: '日常养护',
    type: 'line',
    data: [1.2, 1.5, 1.3, 1.7, 1.6, 1.8],
  },
  {
    name: '维修养护',
    type: 'line',
    data: [0.5, 0.6, 0.7, 0.8, 0.9, 1.0],
    show: false, // 默认隐藏
  },
  {
    name: '应急响应',
    type: 'line',
    data: [10, 15, 20, 25, 30, 35],
    show: false, // 默认隐藏
  },
],
(2) 添加动画效果

可以通过 animation 属性为折线图添加动画效果。例如:

series: [
  {
    name: '日常养护',
    type: 'line',
    data: [1.2, 1.5, 1.3, 1.7, 1.6, 1.8],
    animation: true, // 开启动画
  },
],
(3) 响应式布局

确保图表容器的宽度和高度是响应式的,可以结合 CSS 或 JavaScript 动态调整图表大小。例如:

window.addEventListener('resize', () => {
  myChart.resize();
});

总结

通过上述代码,你可以在 Vue 中实现以下功能:

  1. 默认隐藏某些图例(如“日常养护”)。
  2. 点击图例时动态显示或隐藏对应的数据系列。
  3. 动态更新图表配置,提升用户体验。

这种方法适用于需要灵活控制图例显示/隐藏的场景,例如多维度数据分析、实时监控等。

参考

echarts api:Documentation - Apache ECharts

相关文章:

  • MySQL的事务
  • Springboot3.x集成Spring Batch 5.2.1
  • 面试经典150题·LeetCode26·删除有序数组中的重复项·Java
  • 18.redis基本操作
  • 内积相似系数——内积度量相似系数
  • html 列表循环滚动,动态初始化字段数据
  • Android 隐藏手势模式下输入法的BackButton和ImeSwitchButton
  • Vue项目中Vuex在util引入,断点存在default
  • EI复现:蜣螂优化算法变体合集上新,改进正弦算法引导的蜣螂优化算法
  • ts中 构造器
  • 23种设计模式-结构型模式-桥接器
  • 【CF】Day20——Codeforces Round 969 (Div. 2) C
  • STM32 CAN学习(一)
  • linux-- 0. C语言过、Java半静对、Python纯动和C++对+C
  • mapState 函数的用法
  • 7.5 分治:归并:LeetCode 剑指 Offer 51.数组中的逆序对
  • docker 搭建部署知识库XWIKI
  • 【嵌入式学习3】信息安全 - SSH协议
  • JAVA反序列化深入学习(六):CommonsCollections4
  • jQuery 入门到精通
  • 网站设计公司成都/百度小程序seo
  • 网站广告位制作/扬州seo优化
  • .net和php那个做网站好/上海百度推广优化公司
  • 网站 制作公司/建立公司网站需要多少钱
  • 阿里云搭建企业网站/开创集团与百度
  • 图片网站推广/软文写作经验是什么