Vue2中使用Echarts

1.安装echarts

在项目根目录下,使用npm或yarn安装ECharts:

npm install echarts --save

或者

yarn add echarts

2.在相应的vue页面中引入echarts

<script>
import * as echarts from "echarts";
</script>

3.代码解析

<template><div ref="chart" style="width: 600px; height: 400px;"></div>
</template><script>
import * as echarts from 'echarts';export default {name: 'MyChart',mounted() {this.initChart();},methods: {initChart() {// 获取DOM元素const chartDom = this.$refs.chart;// 初始化ECharts实例const myChart = echarts.init(chartDom);// 配置图表选项const option = {title: {text: 'ECharts 入门示例'},tooltip: {},xAxis: {data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']},yAxis: {},series: [{name: '销量',type: 'bar',data: [5, 20, 36, 10, 10, 20]}]};// 使用配置项显示图表myChart.setOption(option);}}
};
</script>

 1.定义了一个用于渲染图表的DOM元素。

<div ref="chart" style="width: 600px; height: 400px;"></div>

2.生命周期钩子用于在组件挂载后初始化图表。

mounted() {this.initChart();},

3.initChart() 方法用于初始化ECharts实例并设置图表配置。

        获取DOM元素

const chartDom = this.$refs.chart;
  • this.$refs.chart 是 Vue 中通过 ref 属性获取 DOM 元素的方式。

  • 在模板中,<div ref="chart"></div> 定义了一个 DOM 元素,this.$refs.chart 就是对这个元素的引用。

  • 这个 DOM 元素将作为 ECharts 图表的容器。

        初始化 ECharts 实例

const myChart = echarts.init(chartDom);
  • echarts.init(chartDom) 是 ECharts 的初始化方法,它会将 chartDom 元素初始化为一个 ECharts 实例。

  • myChart 是 ECharts 实例的引用,后续可以通过它来操作图表(例如更新数据、调整配置等)。

        配置图表选项

const option = {title: {text: 'ECharts 入门示例'},tooltip: {},xAxis: {data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']},yAxis: {},series: [{name: '销量',type: 'bar',data: [5, 20, 36, 10, 10, 20]}]
};
  • option 是 ECharts 的配置对象,用于定义图表的外观和行为。

  • title:图表的标题,text 属性设置标题内容。

  • tooltip:提示框组件,当鼠标悬停在图表上时会显示提示信息。

  • xAxis:X 轴配置,data 属性设置 X 轴的数据项(这里是商品的名称)。

  • yAxis:Y 轴配置,这里没有额外配置,ECharts 会自动根据数据生成 Y 轴。

  • series:系列列表,每个系列代表一组数据。

    • name:系列的名称,会显示在图例和提示框中。

    • type:图表的类型,这里是柱状图(bar)。

    • data:系列的数据,对应 Y 轴的值。

        使用配置项显示图表

myChart.setOption(option);
  • myChart.setOption(option) 将配置对象 option 应用到 ECharts 实例中,从而渲染出图表。

  • 这一步是必须的,否则图表不会显示。

4.后端获取数据如何在echarts中使用

<template><div ref="chart" style="width: 600px; height: 400px;"></div>
</template><script>
import * as echarts from 'echarts';
import axios from 'axios';export default {name: 'MyChart',data() {return {myChart: null, // 用于保存 ECharts 实例xAxisData: [], // X 轴数据yAxisData: []  // Y 轴数据};},mounted() {this.initChart();this.fetchData(); // 组件挂载后获取数据},methods: {// 初始化图表initChart() {const chartDom = this.$refs.chart;this.myChart = echarts.init(chartDom);},// 从后端获取数据async fetchData() {try {// 发送请求获取数据const response = await axios.get('https://api.example.com/chart-data');const data = response.data;// 更新 X 轴和 Y 轴数据this.xAxisData = data.xAxis;this.yAxisData = data.yAxis;// 更新图表this.updateChart();} catch (error) {console.error('Failed to fetch data:', error);}},// 更新图表updateChart() {if (this.myChart) {const option = {title: {text: '动态数据示例'},tooltip: {},xAxis: {data: this.xAxisData // 使用从后端获取的 X 轴数据},yAxis: {},series: [{name: '销量',type: 'bar',data: this.yAxisData // 使用从后端获取的 Y 轴数据}]};// 使用配置项显示图表this.myChart.setOption(option);}}},beforeDestroy() {// 销毁 ECharts 实例if (this.myChart) {this.myChart.dispose();}}
};
</script>

数据定义

data() {return {myChart: null, // 用于保存 ECharts 实例xAxisData: [], // X 轴数据yAxisData: []  // Y 轴数据};
}
  • myChart:用于保存 ECharts 实例,方便后续操作。

  • xAxisData 和 yAxisData:分别用于存储从后端获取的 X 轴和 Y 轴数据。

初始化图表

initChart() {const chartDom = this.$refs.chart;this.myChart = echarts.init(chartDom);
}
  • 在 mounted 钩子中调用 initChart,初始化 ECharts 实例。

获取后端数据

async fetchData() {try {const response = await axios.get('https://api.example.com/chart-data');const data = response.data;// 更新 X 轴和 Y 轴数据this.xAxisData = data.xAxis;this.yAxisData = data.yAxis;// 更新图表this.updateChart();} catch (error) {console.error('Failed to fetch data:', error);}
}
  • 使用 axios.get 发送 HTTP 请求,获取后端数据。

  • 假设后端返回的数据格式为:

    {"xAxis": ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"],"yAxis": [5, 20, 36, 10, 10, 20]
    }
  • 将获取到的数据赋值给 xAxisData 和 yAxisData,然后调用 updateChart 更新图表。

更新图表

updateChart() {if (this.myChart) {const option = {title: {text: '动态数据示例'},tooltip: {},xAxis: {data: this.xAxisData // 使用从后端获取的 X 轴数据},yAxis: {},series: [{name: '销量',type: 'bar',data: this.yAxisData // 使用从后端获取的 Y 轴数据}]};// 使用配置项显示图表this.myChart.setOption(option);}
}
  • 根据 xAxisData 和 yAxisData 动态生成图表的配置项 option

  • 调用 this.myChart.setOption(option) 更新图表。

销毁 ECharts 实例

beforeDestroy() {if (this.myChart) {this.myChart.dispose();}
}
  • 在组件销毁前,调用 dispose 方法销毁 ECharts 实例,避免内存泄漏。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/502562.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[Linux]进程间通信-共享内存与消息队列

目录 一、共享内存 1.共享内存的原理 2.共享内存的接口 命令行 创建共享内存 共享内存的挂接 去掉挂接 共享内存的控制 3.共享内存的使用代码 Comm.hpp--封装了操作接口 客户端--写入端 服务器--读取端 4.管道实现共享内存的同步机制 二、消息队列 1.底层原理 2…

凸包(convex hull)简述

凸包&#xff08;convex hull&#xff09;简述 这里主要介绍二维凸包&#xff0c;二维凸多边形是指所有内角都在 [ 0 , Π ] [0,\Pi ] [0,Π]范围内的简单多边形。 凸包是指在平面上包含所有给定点的最小凸多边形。 数学定义&#xff1a;对于给定集合 X X X&#xff0c;所有…

【ArcGISPro/GeoScenePro】检查多光谱影像的属性并优化其外观

数据 https://arcgis.com/sharing/rest/content/items/535efce0e3a04c8790ed7cc7ea96d02d/data 操作 其他数据 检查影像的属性 熟悉检查您正在使用的栅格属性非常重要。

提升汽车金融租赁系统的效率与风险管理策略探讨

内容概要 在汽车金融租赁系统这个复杂的生态中&#xff0c;提升整体效率是每个企业都渴望达成的目标。首先&#xff0c;优化业务流程是实现高效运行的基础。通过分析目前的流程&#xff0c;找出冗余环节并进行简化&#xff0c;能够帮助企业缩短审批时间&#xff0c;提高客户满…

以太网UDP协议栈实现(支持ARP、ICMP、UDP)--FPGA学习笔记26

纯verilog实现&#xff0c;仅使用锁相环IP、FIFO IP&#xff0c;方便跨平台移植。支持ping指令。 以太网系列文章&#xff1a; 以太网ICMP协议(ping指令)——FPGA学习笔记25-CSDN博客 以太网ARP协议——FPGA学习笔记23-CSDN博客 以太网PHY_MDIO通信&#xff08;基于RTL821…

edeg插件/扩展推荐:助力生活工作

WeTab 此插件在我看来有2个作用 1.改变edeg的主页布局和样式,使其更加精简,无广告 2.提供付费webtab Ai(底层是chatGpt) 沉浸式翻译 此插件可翻译网页的内容 假设我们浏览github 翻译前 翻译后 Better Ruler 可以对网页的距离进行测量 适合写前端的小伙伴 用法示例:

java项目之校园管理系统的设计与实现(源码+文档)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的校园管理系统的设计与实现。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; springboot校园…

设计模式 结构型 适配器模式(Adapter Pattern)与 常见技术框架应用 解析

适配器模式&#xff08;Adapter Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许将一个类的接口转换成客户端所期望的另一个接口&#xff0c;从而使原本因接口不兼容而无法一起工作的类能够协同工作。这种设计模式在软件开发中非常有用&#xff0c;尤其是在需要集成…

打造三甲医院人工智能矩阵新引擎(一):文本大模型篇--基于GPT-4o的探索

一、引言 当今时代,人工智能技术正以前所未有的速度蓬勃发展,深刻且广泛地渗透至各个领域,医疗行业更是这场变革的前沿阵地。在人口老龄化加剧、慢性疾病患病率上升以及人们对健康需求日益增长的大背景下,三甲医院作为医疗体系的核心力量,承担着极为繁重且复杂的医疗任务。…

S7-200采集频率信号

S7-200可以借助高速计数器完成频率信号采集&#xff0c;接入流量计、转速等信号。官方给出的程序块无法完成多路同时采集&#xff0c;需要自己进行修改。 首先下载官方的频率采集库 SIOS 下载后导入library&#xff0c;在library中出现Frequency(v1.0) 拖进ladder后&#xf…

专家混合(MoE)大语言模型:免费的嵌入模型新宠

专家混合&#xff08;MoE&#xff09;大语言模型&#xff1a;免费的嵌入模型新宠 今天&#xff0c;我们深入探讨一种备受瞩目的架构——专家混合&#xff08;Mixture-of-Experts&#xff0c;MoE&#xff09;大语言模型&#xff0c;它在嵌入模型领域展现出了独特的魅力。 一、M…

【Vue】分享一个快速入门的前端框架以及如何搭建

先上效果图: 登录 菜单: 下载地址: 链接&#xff1a;https://pan.baidu.com/s/1m-ZlBARWU6_2n8jZil_RAQ 提取码&#xff1a;ui20 … 主要是可以自定义设置token,更改后端请求地址较为方便。 应用设置: 登录与token设置: 在这里设置不用登录,可以请求的接口: request.js i…

MySQL叶子节点为啥使用双向链表?不使用单向呢?

文章内容收录到个人网站&#xff0c;方便阅读&#xff1a;http://hardyfish.top/ 文章内容收录到个人网站&#xff0c;方便阅读&#xff1a;http://hardyfish.top/ 文章内容收录到个人网站&#xff0c;方便阅读&#xff1a;http://hardyfish.top/ MySQL 中的 B 树索引&#x…

用户界面的UML建模10

非正常的可视反馈可伴随着同步事件发生&#xff0c;而同步事件可由系统动作产生。但是&#xff0c;可以分别对它们进行建模。 在下节中将对这些特殊的事件依次进行论述。 6.1 异常处理建模 异常&#xff0c;由Meyer 定义[16],其作为运行时事件&#xff08;run-time events&a…

最新版Chrome浏览器加载ActiveX控件之CFCA安全输入控件

背景 CFCA安全输入控件用于保证用户在浏览器、桌面客户端、移动客户端中输入信息的安全性&#xff0c;防止运行在用户系统上的病毒、木马等恶意程序入侵窃取用户输入的敏感信息。确保用户输入、本地缓存、网络传输整个流程中&#xff0c;输入的敏感信息不被窃取。广泛应用于银行…

0基础跟德姆(dom)一起学AI 自然语言处理10-LSTM模型

1 LSTM介绍 LSTM&#xff08;Long Short-Term Memory&#xff09;也称长短时记忆结构, 它是传统RNN的变体, 与经典RNN相比能够有效捕捉长序列之间的语义关联, 缓解梯度消失或爆炸现象. 同时LSTM的结构更复杂, 它的核心结构可以分为四个部分去解析: 遗忘门输入门细胞状态输出门…

力扣283 移动零

void moveZeroes(int* nums, int numsSize) {int last_non_zero_found_at 0;for (int i 0; i < numsSize; i) {if (nums[i] ! 0) {// 交换 nums[last_non_zero_found_at] 和 nums[i]int temp nums[last_non_zero_found_at];nums[last_non_zero_found_at] nums[i];nums[i…

LookingGlass使用

文章目录 背景编译安装运行限制使用场景总结参考 背景 Looking Glass 是一款开源应用程序&#xff0c;可以直接使用显卡直通的windows虚拟机。 常见环境是Linux hostwindows guest&#xff0c;基本部署结构图&#xff1a; 编译 git clone --recursive https://github.com/g…

JVM学习:CMS和G1收集器浅析

总框架 一、Java自动内存管理基础 1、运行时数据区 运行时数据区可分为线程隔离和线程共享两个维度&#xff0c;垃圾回收主要是针对堆内存进行回收 &#xff08;1&#xff09;线程隔离 程序计数器 虚拟机多线程是通过线程轮流切换、分配处理器执行时间来实现的。为了线程切换…

关于 webservice 日志中 源IP是node IP的问题,是否能解决换成 真实的客户端IP呢

本篇目录 1. 问题背景2. 部署gitlab 17.52.1 添加repo源2.2 添加repo源 下载17.5.0的charts包2.3 修改values文件2.3.1 hosts修改如下2.3.2 appConfig修改如下2.3.3 gitlab下的sidekiq配置2.3.4 certmanager修改如下2.3.5 nginx-ingress修改如下2.3.6 <可选> prometheus修…