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

使用 ECharts 与 Vue 构建数据可视化组件

在前端开发中,数据可视化是非常重要的一部分。ECharts 作为一个功能强大且易于使用的开源数据可视化库,被广泛应用于各种图表展示需求中。而 Vue.js 是当下流行的前端框架之一,它的数据驱动和组件化开发模式让我们能轻松地将 ECharts 集成到 Vue 组件中。本篇博客将通过一个实际的代码示例,逐步解析如何将 ECharts 与 Vue 结合使用,构建可复用的数据可视化组件。

1. Vue 模板部分
<template><div ref="chart" id="chart-container" style="width: 100%; height: 400px;"></div>
</template>

在 Vue 组件的模板部分,我们定义了一个 div,它将作为 ECharts 的容器。ref="chart" 是 Vue 中的一个引用,用于在 JavaScript 中获取这个 DOM 元素,style 用于设置图表的宽高。

2. 脚本部分 - Props 定义
props: {source: {type: [Array, Object],required: true},tooltip: {type: Array,default: () => []},xName: {type: String,default: ''},yName: {type: String,default: ''},singleSelect: {type: Boolean,default: false},type: {type: String,required: true},RequestParameters: {type: Object,default: () => ({})}
},

props 是 Vue 组件用于接收父组件传递数据的属性。在这里我们定义了多个属性:

  • source: 必填,表示图表的数据源,可以是数组或对象。
  • tooltip: 用于显示自定义的提示信息,默认为空数组。
  • xNameyName: 分别为 X 轴和 Y 轴的名称。
  • singleSelect: 布尔值,控制图例是否为单选。
  • type: 图表的类型,如线图、柱状图等。
  • RequestParameters: 请求参数,用于一些特定的业务需求,默认为空对象。
3. datamounted 钩子
data() {return {chartInstance: null,};
},
mounted() {this.initChart(); // 初始化图表window.addEventListener('resize', this.handleResize); // 监听窗口大小变化
},
beforeDestroy() {window.removeEventListener('resize', this.handleResize);if (this.chartInstance) {this.chartInstance.dispose(); // 销毁图表实例}
}
  • data: Vue 组件的局部数据。在这里,我们定义了 chartInstance,用于存储 ECharts 实例。
  • mounted: Vue 的生命周期钩子函数,当组件挂载到 DOM 后会触发。我们在这里初始化图表并监听窗口大小变化,以便图表在窗口尺寸变化时能够自适应。
  • beforeDestroy: 在组件销毁前,我们移除窗口的 resize 事件监听器,并销毁 ECharts 实例,避免内存泄漏。
4. 图表的初始化和更新
methods: {handleResize() {if (this.chartInstance) {this.chartInstance.resize(); // 调用图表实例的 resize 方法}},initChart() {const chartDom = this.$refs.chart; // 通过 ref 获取 DOMif (chartDom) {this.chartInstance = echarts.init(chartDom); // 初始化 ECharts 实例this.updateChart(); // 更新图表} else {console.error("图表容器未找到");}},updateChart() {let option = {};switch (this.type) {case 'timeLine':option = this.getTimeLineDataTicks();break;// 省略其他 casedefault:console.warn(`不支持的图表类型: ${this.type}`);}if (option && this.chartInstance) {this.chartInstance.setOption(option); // 设置图表配置项}},
}
  • handleResize: 当窗口大小变化时,调用图表实例的 resize 方法让图表自适应。
  • initChart: 使用 this.$refs.chart 获取 DOM 元素,调用 echarts.init 方法来初始化 ECharts 实例。
  • updateChart: 根据 type 判断要渲染的图表类型,并调用对应的生成图表配置的方法,如 getTimeLineDataTicks。然后将生成的配置传入 chartInstance.setOption 方法,完成图表的渲染。
5. 图表配置的生成

接下来,我们来看一个具体的图表配置生成函数:

getTimeLineDataTicks() {const { source, xName, yName, singleSelect } = this;const xAxis = [];const legend = [];const series = [];this.source.forEach(item => {const date = new Date(item.name);item.name = date.toLocaleString(); if (!xAxis.includes(item.name)) xAxis.push(item.name);if (!legend.includes(item.group)) legend.push(item.group);});legend.forEach(group => {const seriesData = source.filter(item => item.group === group).map(item => item.value);series.push({name: group,type: 'line',data: seriesData,connectNulls: true,showSymbol: true,label: {show: true,position: 'top',formatter: '{c}',},});});return {tooltip: {trigger: 'axis',formatter(params) {let tooltip = `${xName} : ${params[0].name}<br/>`;params.forEach(param => {tooltip += `<span style="background-color:${param.color};"></span>`;tooltip += `${param.seriesName} : ${param.value}<br/>`;});return tooltip;}},legend: {data: legend,selectedMode: singleSelect ? 'single' : 'multiple',},xAxis: {type: 'category',name: xName,data: xAxis,boundaryGap: false,},yAxis: {type: 'value',name: yName,},series: series,};
}
  • getTimeLineDataTicks: 这个方法生成时间轴折线图的配置项。

    • 首先从 source 中提取 X 轴数据(xAxis)、图例数据(legend)和每个系列(series)的数据点。
    • 使用 ECharts 的配置格式,定义图表的 tooltiplegendxAxisyAxis,最后返回整个图表的配置对象。
  • tooltip: 鼠标悬停时显示的提示框,通过 formatter 方法自定义提示信息。

  • legend: 图例部分,用户可以根据图例显示或隐藏某些系列的数据。

  • xAxisyAxis: 定义 X 轴和 Y 轴的样式与数据。

  • series: 定义图表中的每个系列数据,这里是折线图。

6. 样式部分
<style scoped>
.chart {width: 100%;height: 400px;
}
</style>
  • 样式部分很简单,我们为 chart 容器设置了宽度和高度。
7. 完整的工作流程
  1. 组件被挂载到 DOM 上后,mounted 钩子被触发,调用 initChart 方法。
  2. initChart 方法中,通过 this.$refs.chart 获取图表的 DOM 容器,并使用 echarts.init 初始化 ECharts 实例。
  3. 根据传入的 type,在 updateChart 方法中调用不同的图表配置生成方法(如 getTimeLineDataTicks)。
  4. 生成的配置通过 chartInstance.setOption 方法应用到图表上,最终完成图表的渲染。
  5. 当窗口大小发生变化时,handleResize 会自动调整图表的尺寸。

总结

通过 Vue 和 ECharts 的结合,我们可以轻松实现一个高度可复用的图表组件。组件化的设计让我们可以将不同类型的图表封装在一起,并且根据传入的 type 动态渲染出不同的图表。无论是折线图、柱状图还是复杂的树状图,都能通过 ECharts 强大的图表配置系统轻松实现。

希望这篇博客能够帮助你更好地理解如何在 Vue 项目中集成 ECharts,并且为你今后的数据可视化项目提供一些思路和参考。

相关文章:

使用 ECharts 与 Vue 构建数据可视化组件

在前端开发中&#xff0c;数据可视化是非常重要的一部分。ECharts 作为一个功能强大且易于使用的开源数据可视化库&#xff0c;被广泛应用于各种图表展示需求中。而 Vue.js 是当下流行的前端框架之一&#xff0c;它的数据驱动和组件化开发模式让我们能轻松地将 ECharts 集成到 …...

Yocto 项目 - 共享状态缓存 (Shared State Cache) 机制

引言 在嵌入式开发中&#xff0c;构建效率直接影响项目的开发进度和质量。Yocto 项目通过其核心工具 BitBake 提供了灵活而强大的构建能力。然而&#xff0c;OpenEmbedded 构建系统的传统设计是从头开始构建所有内容&#xff08;Build from Scratch&#xff09;&#xff0c;这…...

Unity3D仿星露谷物语开发9之创建农场Scene

1、目标 绘制农场的场景。通过不同Sorting Layer控制物体的显示优先级&#xff0c;绘制Tilemap地图&#xff0c;添加Tilemap Collider碰撞器&#xff0c;同时添加Composite Collider碰撞器优化性能。 ps&#xff1a;绘制Tilemap的技巧&#xff1a;通过"Shift [" 可…...

STM32-笔记20-测量按键按下时间

1、按键按下的时间-思路 我们先检测下降沿信号&#xff0c;检测到以后&#xff0c;在回调函数里切换成检测上升沿信号&#xff0c;当两个信号都检测到的时候&#xff0c;这段时间就是按键按下的时间&#xff0c;如图所示&#xff1a;>N*(ARR1)CCRx的值 N是在这段时间内&…...

2024年12月30日Github流行趋势

项目名称&#xff1a;free-programming-books 项目地址url&#xff1a;https://github.com/EbookFoundation/free-programming-books项目语言&#xff1a;HTML历史star数&#xff1a;343,398今日star数&#xff1a;246项目维护者&#xff1a;vhf, eshellman, davorpa, MHM5000,…...

SAP PP bom历史导出 ALV 及XLSX 带ECN号

bom总数 104W PS超过XLSX上限 &#xff0c;那就分文件 *&---------------------------------------------------------------------* *& Report ZRPT_PP_BOM_HIS_ECN *&---------------------------------------------------------------------* *& tcode:zpp0…...

使用WebRTC进行视频通信

一、WebRTC技术简介 什么是WebRTC&#xff1f; 是一种支持浏览器之间实时音频、视频和数据传输的开放源代码项目。它允许开发者在不需要任何第三方插件或软件的情况下实现点对点的实时通信。WebRTC已经成为现代Web应用中的关键技术&#xff0c;为开发者提供了强大的工具和API…...

npm ERR! ECONNRESET 解决方法

问题&#xff1a;npm 命令遇到的错误是 ECONNRESET&#xff0c;这通常与网络连接问题相关。设置代理解决问题。 一、查看当前代理设置 npm config get proxy npm config get https-proxy二、设置代理 npm config set proxy http://your-proxy-address:port npm config set h…...

【连续学习之SS-IL算法】2021年CPVR会议论文Ss-il:Separated softmax for incremental learning

1 介绍 年份&#xff1a;2021 期刊&#xff1a; 2021CPVR Ahn H, Kwak J, Lim S, et al. Ss-il: Separated softmax for incremental learning[C]//Proceedings of the IEEE/CVF International conference on computer vision. 2021: 844-853. 本文提出的SS-IL&#xff08…...

Go+chromedp实现Web UI自动化测试

1.为什么使用go进行UI自动化测试&#xff1f; 速度&#xff1a;Go速度很快&#xff0c;这在运行包含数百个UI测试的测试套件时是一个巨大的优势 并发性&#xff1a;可以利用Go的内置并发性(goroutines)来并行化测试执行 简单&#xff1a;Go的简约语法允许您编写可读且可维护…...

【MySQL 高级特性与性能优化】

MySQL 高级特性与性能优化 一、MySQL 存储引擎 &#xff08;一&#xff09;InnoDB 存储引擎 1. 特点 支持事务&#xff1a;InnoDB 是 MySQL 中提供完整 ACID 事务支持的存储引擎&#xff0c;这意味着它能够保证数据库操作在复杂的并发环境下的一致性、隔离性、原子性和持久…...

Spring Boot教程之三十九: 使用 Maven 将 Spring Boot 应用程序 Docker 化

如何使用 Maven 将 Spring Boot 应用程序 Docker 化&#xff1f; Docker是一个开源容器化工具&#xff0c;用于在隔离环境中构建、运行和管理应用程序。它方便开发人员捆绑其软件、库和配置文件。Docker 有助于将一个容器与另一个容器隔离。在本文中&#xff0c;为了将Spring B…...

微信小程序开发示例

微信小程序开发涉及多个方面&#xff0c;包括页面布局、交互逻辑、数据处理等。以下是一个简单的微信小程序开发示例&#xff0c;包括页面布局、样式定义、交互逻辑等方面的内容。 一、页面布局&#xff08;WXML&#xff09; <!-- index.wxml --> <view class"…...

【机器学习】概述

文章目录 1. 机器学习三步骤2. 机器学习图谱2.1 任务类型 (Task)2.2 模型选择 (Methods)2.3 学习场景 (Scenario) 1. 机器学习三步骤 定义一个模型 (Define a set of function) 选择一组合适的函数来表示模型。 评估模型好坏 (Goodness of function) 找到一个损失函数&#xf…...

音视频采集推流时间戳记录方案

音视频同步更多文章 深入理解音视频pts&#xff0c;dts&#xff0c;time_base以及时间数学公式_视频pts计算-CSDN博客 ffplay音视频同步分析_ffplay 音视频同步-CSDN博客 音视频采集打时间戳设计 实时音视频数据的采集和处理场景。具体来说: 采集阶段: 在音视频数据采集过…...

【Linux】:线程安全 + 死锁问题

&#x1f4c3;个人主页&#xff1a;island1314 &#x1f525;个人专栏&#xff1a;Linux—登神长阶 ⛺️ 欢迎关注&#xff1a;&#x1f44d;点赞 &#x1f442;&#x1f3fd;留言 &#x1f60d;收藏 &#x1f49e; &#x1f49e; &#x1f49e; 1. 线程安全和重入问题&…...

【深度学习】时间序列表示方法

自然界除了2D的图片数据之外&#xff0c;还有语音、文字&#xff0c;这些数据都有时间的先后顺序的。对于2D的图像的数据&#xff0c;可以用RGB值来表示像素的色彩度。语音可以用信号幅度值来表示&#xff0c;而Pytorch没有自带String支持&#xff0c;在表示文字之前需要进行Em…...

1.微服务灰度发布落地实践(方案设计)

文章目录 前言灰度发布的优点设计概要系统架构图流量控制客户端服务端 路由路径应用客户端实现核心组件分析1.网关2. spring-cloud3. dubbo4. nocas5. thread6. message queue 前言 微服务架构中的灰度发布&#xff08;也称为金丝雀发布或渐进式发布&#xff09;是一种在不影响…...

【UE5 C++课程系列笔记】15——Assert的基本使用

目录 概念 一、Check 二、Verify 三、Ensure 对比 基本使用 一、check的基本使用 二、ensure的基本使用 三、verify的基本使用 概念 assert 可在开发期间帮助检测和诊断不正常或无效的运行时条件。这些条件通常检查是否指针为非空、除数为非零、函数并非递归运行&…...

kubernetes Gateway API-1-部署和基础配置

文章目录 1 部署2 最简单的 Gateway3 基于主机名和请求头4 重定向 Redirects4.1 HTTP-to-HTTPS 重定向4.2 路径重定向4.2.1 ReplaceFullPath 替换完整路径4.2.2 ReplacePrefixMatch 替换路径前缀5 重写 Rewrites5.1 重写 主机名5.2 重写 路径5.2.1 重新完整路径5.2.1 重新部分路…...

UE5动画开发实战:Modify Curve节点的5种Apply Mode详解(附应用场景)

UE5动画开发实战&#xff1a;Modify Curve节点的5种Apply Mode详解&#xff08;附应用场景&#xff09; 在UE5动画开发中&#xff0c;曲线控制是提升角色表现力的关键。Modify Curve节点作为动画蓝图中的重要工具&#xff0c;其五种Apply Mode模式的选择直接影响最终动画效果的…...

Windows 11 LTSC微软商店安装高效解决方案:从问题到实施的完整指南

Windows 11 LTSC微软商店安装高效解决方案&#xff1a;从问题到实施的完整指南 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore Windows 11 LTSC&#…...

GEMMA-3像素级JRPG界面实测:零基础也能看懂图片的AI神器

GEMMA-3像素级JRPG界面实测&#xff1a;零基础也能看懂图片的AI神器 1. 复古像素风遇上AI视觉革命 当90年代JRPG的怀旧美学撞上Google最先进的多模态AI&#xff0c;会擦出怎样的火花&#xff1f;GEMMA-3像素级JRPG界面给出了惊艳答案。这款名为"Pixel Station"的工…...

论文阅读:AIED 2024 RuffleRiley: Insights from Designing and Evaluating a Large Language Model-Based Con

总目录 大模型相关研究&#xff1a;https://blog.csdn.net/WhiffeYF/article/details/142132328 https://arxiv.org/abs/2404.17460 Ruffle&Riley: Insights from Designing and Evaluating a Large Language Model-Based Conversational Tutoring System &#x1f4c4; …...

【Vue2-ElementUI】:model、v-model、prop

一、示例代码<!-- 1. :model 语法&#xff1a;el-form 表单绑定 --> <el-form :rules"inputRules" :model"searchForm" ref"searchForm" ...><!-- 2. prop 语法&#xff1a;el-form-item 表单校验绑定 --><el-form-item la…...

Audio Pixel Studio保姆级教程:Windows/Mac/Linux三平台本地部署详解

Audio Pixel Studio保姆级教程&#xff1a;Windows/Mac/Linux三平台本地部署详解 1. 引言&#xff1a;极简像素音频工作站 Audio Pixel Studio是一款基于Streamlit开发的轻量级音频处理Web应用&#xff0c;它将专业级音频处理能力封装在清新简约的界面中。无论你是内容创作者…...

seo高级优化如何利用社交媒体_seo高级优化如何进行技术优化

SEO高级优化如何利用社交媒体 在当前的数字营销环境中&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;已经不再是一个简单的任务&#xff0c;它已经演变成了一个复杂而多层次的过程。SEO高级优化不仅仅涉及内容创作&#xff0c;还包括技术优化、用户体验以及社交媒体的有…...

Vue3集成AntV G6实战:从零构建拓扑图可视化应用

1. 为什么选择Vue3AntV G6做拓扑图&#xff1f; 拓扑图可视化在系统架构设计、网络拓扑分析、依赖关系展示等场景中非常常见。我之前做过一个微服务治理平台的项目&#xff0c;需要直观展示几十个服务之间的调用关系&#xff0c;试过D3.js、ECharts等方案&#xff0c;最后发现A…...

灵感画廊实际作品:基于‘纪实瞬间’预设的城市街景写实图像生成

灵感画廊实际作品&#xff1a;基于‘纪实瞬间’预设的城市街景写实图像生成 “见微知著&#xff0c;凝光成影。将梦境的碎片&#xff0c;凝结为永恒的视觉诗篇。” 今天&#xff0c;我们不谈复杂的参数&#xff0c;也不讲枯燥的部署。我想带你走进一个特别的创作空间——灵感画…...

c++如何读取BMP位图文件并精确提取每个像素点的RGB值【实战】

直接用fread读BMP会错乱因像素数据BGR存储、行末补零对齐且从左下到右上排列&#xff1b;需跳过bfOffBits&#xff0c;按每行字节数对齐读取并反向索引&#xff0c;再手动转为RGB。为什么直接用 fread 读 BMP 文件会得到错乱的 RGB 顺序&#xff1f;BMP 文件头和信息头之后&…...