写一份vue.js使用Echarts渲染多个图表,请求接口的时候,图表HTML一直在loading状态,接口请求完之后开始渲染图表,且图表绑定window.onresize,离开页面之后自动移除resize

时间: 2024-04-05 21:30:43 浏览: 13
好的,下面是一份Vue.js使用Echarts渲染多个图表的代码,以及在请求接口时渲染loading状态,请求完成后渲染图表并绑定window.onresize,离开页面时自动移除resize事件的实现: ```html <template> <div> <div v-if="loading" class="loading">Loading...</div> <div v-else> <div class="chart" ref="chart1"></div> <div class="chart" ref="chart2"></div> <div class="chart" ref="chart3"></div> </div> </div> </template> <script> import echarts from 'echarts' export default { data() { return { loading: true, chartData1: [], chartData2: [], chartData3: [] } }, methods: { fetchData() { // 发送请求获取数据 // ... // 模拟数据 this.chartData1 = [ { name: 'A', value: 10 }, { name: 'B', value: 20 }, { name: 'C', value: 30 } ] this.chartData2 = [ { name: 'D', value: 40 }, { name: 'E', value: 50 }, { name: 'F', value: 60 } ] this.chartData3 = [ { name: 'G', value: 70 }, { name: 'H', value: 80 }, { name: 'I', value: 90 } ] // 渲染图表 this.renderChart() }, renderChart() { // 渲染第一个图表 const chart1 = echarts.init(this.$refs.chart1) chart1.setOption({ xAxis: { data: this.chartData1.map(item => item.name) }, yAxis: {}, series: [{ type: 'bar', data: this.chartData1.map(item => item.value) }] }) // 渲染第二个图表 const chart2 = echarts.init(this.$refs.chart2) chart2.setOption({ xAxis: { data: this.chartData2.map(item => item.name) }, yAxis: {}, series: [{ type: 'bar', data: this.chartData2.map(item => item.value) }] }) // 渲染第三个图表 const chart3 = echarts.init(this.$refs.chart3) chart3.setOption({ xAxis: { data: this.chartData3.map(item => item.name) }, yAxis: {}, series: [{ type: 'bar', data: this.chartData3.map(item => item.value) }] }) // 绑定window.onresize事件 window.addEventListener('resize', this.handleResize) }, handleResize() { // 重新渲染图表 echarts.init(this.$refs.chart1).resize() echarts.init(this.$refs.chart2).resize() echarts.init(this.$refs.chart3).resize() } }, mounted() { this.fetchData() }, beforeDestroy() { // 移除window.onresize事件 window.removeEventListener('resize', this.handleResize) } } </script> <style> .chart { height: 300px; } .loading { font-size: 20px; text-align: center; margin-top: 100px; } </style> ``` 在这份代码中,我们使用了v-if和v-else来控制loading状态和图表的显示。在mounted钩子函数中,我们调用了fetchData方法来发送请求获取数据,模拟数据的部分可以根据实际情况进行修改。 在fetchData方法中,我们首先将loading状态设置为true,表示正在加载,然后发送请求获取数据。在请求完成后,我们将loading状态设置为false,表示加载完成,然后将数据保存到chartData1、chartData2、chartData3中,并调用renderChart方法来渲染图表。 在renderChart方法中,我们分别使用echarts.init来初始化三个图表实例,并设置对应的数据和配置项。然后我们绑定了window.onresize事件,并在handleResize方法中重新渲染图表。 最后,在beforeDestroy钩子函数中,我们移除了window.onresize事件,以防止内存泄漏。

相关推荐

最新推荐

recommend-type

详解vue中使用axios对同一个接口连续请求导致返回数据混乱的问题

主要介绍了详解vue中使用axios对同一个接口连续请求导致返回数据混乱的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

vue如何从接口请求数据

本篇文章主要介绍了vue如何从接口请求数据 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

vue+echarts实现动态绘制图表及异步加载数据的方法

vue写的后台管理,需要将表格数据绘制成图表(折线图,柱状图),图表数据都是通过接口请求回来的。这篇文章主要介绍了vue+echarts 动态绘制图表及异步加载数据的相关知识,需要的朋友可以参考下
recommend-type

vue接口请求加密实例

主要介绍了vue接口请求加密实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Vue3项目打包后部署到服务器 请求不到后台接口解决方法

在本篇文章里小编给大家整理了关于Vue3项目打包后部署到服务器 请求不到后台接口解决方法,有需要的朋友们可以参考下。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。