vue3的echarts从后端获取数据,用于绘制图表

news/2024/12/22 17:53:11/

场景需求:后端采用flask通过pymysql从数据库获取数据,并返回给前端。前端vue3利用axios获取数据并运用到echarts绘制图表。

第一步,vue中引入echarts

首先vue下载echarts

npm install echarts

 然后在main.js文件写如下代码

import {createApp} from 'vue'
import App from './App.vue'
import router from "@/router/index.js"  // 导入路由
import "lib-flexible/flexible"   //导入响应式布局文件,阿里开发的flexible.js
import $ from "jquery"  //导入jQuery
import * as echarts from "echarts"// 注册路由
const app = createApp(App)
app.use(router)
app.mount("#app")// 图表处理
app.config.globalProperties.$echarts = echarts

主要是引入echarts,并进行配置

第二步,在任意要使用echarts的xxx.vue组件中写如下代码

<script>
import axios from "axios"
import {defineComponent, toRaw} from 'vue'export default defineComponent({data() {return {num: [],}},methods: {getData() {let arr = []axios.get("http://127.0.0.1:5000/").then(res => {arr = toRaw(res.data)console.log(arr)let myChart = this.$echarts.init(document.getElementById("myChart"));// 绘制图表console.log(newArray)myChart.setOption({tooltip: {},xAxis: {data: ['衬衫', '羊毛衫', '雪纺衫', '裤子', '高跟鞋', '袜子']},yAxis: {},series: [{name: "销量",type: "bar",data: arr,},]});})},},mounted() {this.getData()},
})</script><template><div id="myChart"></div>
</template><style scoped>#myChart {width: 200px;height: 200px;
}
</style>

解释一下,在script代码中,分别引入axios用于从后端接受数据和引入用于绘制图表的defineComponent, toRaw。然后在data中定义从后端接受数据的变量,我这里定义了一个num。需要根据后端返回的数据类型在data定义不同的变量来接受存储。

然后定义一个接受数据并绘图的函数getData(),首先定义一个arr数组来存储接收到的数据(vue中echarts使用规定的,不能直接用this),然后通过toRow()方法来把接收的后端数据存储到arr数组中。然后下面的代码就是定义了一个图表,在data部分用arr来表示图表数据。

可以看看console打印的


http://www.ppmy.cn/news/1364599.html

相关文章

【Nginx笔记02】通过Nginx服务器转发客户端的WebSocket接口到后端服务

这篇文章&#xff0c;主要介绍如何通过Nginx服务器转发客户端的WebSocket接口到后端服务【知识星球】。 目录 一、Nginx配置WebSocket 1.1、Nginx配置内容 1.2、客户端请求地址 1.3、创建WebSocket测试工程 1.4、启动测试 1.5、WebSocket超时问题 1.5.1、设置超时时间 …

日本韩国媒体宣发稿渠道平台怎么找?跨境出海推广新闻报道营销公司告诉你

【本篇由言同数字科技有限公司原创】随着全球化和互联网的快速发展&#xff0c;品牌出海已经成为众多企业的共同目标。在这个过程中&#xff0c;通过在日本和韩国的媒体上发表文章&#xff0c;可以带来许多重要的意义和益处。在本文中&#xff0c;我们将探讨一下这些意义。 首…

新学期新小艺,华为nova 12 Pro 你的学习好搭子上线啦~

又是一年返校季&#xff0c;全国的莘莘学子开启了自己的新学期&#xff0c;伴随着人工智能快速发展&#xff0c;越来越多的功能正在改变我们的学习和生活。接入了盘古大模型的小艺&#xff0c;以其卓越的智能功能&#xff0c;为我们的生活带来了前所未有的便捷。深受学生党们喜…

浅谈 Linux 网络编程 - 网络字节序

文章目录 前言核心知识关于 小端法关于 大端法网络字节序的转换 函数 前言 在进行 socket 网络编程时&#xff0c;会用到字节流的转换函数、例如 inet_pton、htons 等&#xff0c;那么为什么要用到这些函数呢&#xff0c;本篇主要就是对这部分进行介绍。 核心知识 重点需要记…

LDR6020双盲插音频随便插充电听歌随便插

随着智能手机的普及和功能的日益丰富&#xff0c;手机已经成为我们日常生活中不可或缺的一部分。音乐、电影、游戏等娱乐内容更是丰富了手机的使用体验。而在这其中&#xff0c;音频转接器的作用愈发凸显&#xff0c;特别是在边听边充的场景下&#xff0c;一款高效且便捷的手机…

雾锁王国Enshrouded服务器CPU内存配置怎么选择?

雾锁王国/Enshrouded服务器CPU内存配置如何选择&#xff1f;阿里云服务器网aliyunfuwuqi.com建议选择8核32G配置&#xff0c;支持4人玩家畅玩&#xff0c;自带10M公网带宽&#xff0c;1个月90元&#xff0c;3个月271元&#xff0c;幻兽帕鲁服务器申请页面 https://t.aliyun.com…

Flutter中高级JSON处理:使用json_serializable进行深入定制

Flutter中高级JSON处理 使用json_serializable库进行深入定制 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at: https://jclee95.blog.csdn.netEmail: 291148484163.com. Shenzhen ChinaAddress of this article:https://blog.csdn.net/qq_28550263/article/details/1363…

【Qt学习】QLineEdit 控件 属性与实例(登录界面,验证密码,正则表达式)

文章目录 1. 介绍2. 实例使用2.1 登录界面2.2 对比两次密码是否相同2.3 通过按钮显示当前输入的密码&#xff08;并对2.2进行优化&#xff09;2.4 结语 3. 正则表达式3.1 QRegExp3.2 验证输入内容 4. 资源代码 1. 介绍 关于 QLineEdit 的详细介绍&#xff0c;可以去查阅官方文…