Vue3 封装ECharts 组件 抽离复用 包含图表随着窗口宽高变化而变化

本文主要是介绍Vue3 封装ECharts 组件 抽离复用 包含图表随着窗口宽高变化而变化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 ECharts:一个基于 JavaScript 的开源可视化图表库。

目录

前言

1、目的

2、功能

一、介绍

1、官方文档:Apache ECharts

2、官方示例

二、准备工作

1、安装依赖包

 2、示例版本 

三、使用步骤

1、在单页面引入 ' echarts '

2、指定容器并设置容器宽高

3、数据处理(关键点) - 部分代码已省略,可看文末的完整示例

四、完整示例

ECharts.vue

Example.vue

Index.vue


前言

1、目的

  • 避免重复的代码造成冗余,抽离封装提高复用性
  • 代码逻辑更加清晰,方便后期维护

2、功能

  • 可灵活使用组件传递 option
  • 图表自适应宽高
  • 可动态获取后端数据

一、介绍

1、官方文档:Apache ECharts

Apache EChartsApache ECharts,一款基于JavaScript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。https://echarts.apache.org/zh/index.html

2、官方示例

二、准备工作

1、安装依赖包

npm install echarts --save

 2、示例版本 

"echarts": "^5.4.2",

三、使用步骤

1、在单页面引入 ' echarts '

import * as echarts from "echarts";

注:上面的代码会引入 ECharts 中所有的图表和组件,如果你不想引入所有组件,也可以使用 ECharts 提供的按需引入的接口来打包必须的组件。详见官方文档:在项目中引入 ECharts - 入门篇 - Handbook - Apache ECharts

2、指定容器并设置容器宽高

<template><div class="wrap"></div>
</template><style lang="scss" scoped>
.wrap {width: 800px;height: 600px;overflow: hidden;
}
</style>

3、数据处理(关键点) - 部分代码已省略,可看文末的完整示例

        1)使用markRaw

const initChart = () => {// 初始化echartmyChart.value = markRaw(echarts.init(document.getElementById(props.id) as HTMLDivElement));// 设置true清空echart缓存myChart.value.setOption(props.options, true);
};

注:ECharts会被在Vue内部转换成响应式对象,从而在resize 的时候获取不到

使用 Vue的API , markRaw,标记一个对象,使其不能成为一个响应式对象

        2)使用 ResizeObserver + resize

// 页面挂载,开始绘制图表
onMounted(() => {nextTick(() => {initChart();resizeEle.value = new ResizeObserver((entries) => {for (let entry of entries) {const { width, height } = entry.contentRect;myChart.value.resize({ width, height });}});// 传入需要监听的DOM元素resizeEle.value.observe(chartRef.value);window.addEventListener('resize', resize);});
});

注:ResizeObserver / resize / element-resize-detector的详细文章 =》CSDN

四、完整示例

ECharts.vue

<template><div :id="id" :class="className" ref="chartRef" :style="{ width, height }" />
</template>
<script setup lang="ts">
import * as echarts from 'echarts';
import { ref, defineProps, watch, onMounted, onUnmounted } from 'vue';
const myChart = ref();
const timerTooltip = ref();
const resizeEle = ref();
const drawTiming = ref();
const chartRef = ref();const props = defineProps({options: {type: Object,default: () => ({}),required: true,},trendsTooltip: {type: Boolean,default: false,},id: {type: String,default: 'chart',required: true,},className: {type: String,default: 'chart',},width: {type: String,default: '100%',},height: {type: String,default: '300px',},
});const resize = () => {clearTimeout(drawTiming.value);drawTiming.value = setTimeout(() => {let { clientWidth: width, clientHeight: height } = chartRef.value.parentElement;myChart.value.resize({ width, height });}, 200);
};const initChart = () => {// 初始化echartmyChart.value = markRaw(echarts.init(document.getElementById(props.id) as HTMLDivElement));// 设置true清空echart缓存myChart.value.setOption(props.options, true);
};// 页面挂载,开始绘制图表
onMounted(() => {nextTick(() => {initChart();resizeEle.value = new ResizeObserver((entries) => {for (let entry of entries) {const { width, height } = entry.contentRect;myChart.value.resize({ width, height });}});// 传入需要监听的DOM元素resizeEle.value.observe(chartRef.value);window.addEventListener('resize', resize);});
});// 页面卸载,销毁事件和实例
onUnmounted(() => {// 取消对所有节点的监听resizeEle.value.disconnect(chartRef.value);window.removeEventListener('resize', resize);myChart.value.dispose();myChart.value = null;clearTimeout(drawTiming.value);drawTiming.value = null;
});// 监听图表数据时候变化,重新渲染图表
watch(() => props.options,() => {nextTick(() => {initChart();});// }},{ deep: true }
);
</script>

Example.vue

<template><Echarts :options="options" :trendsTooltip="trendsTooltip" :id="'chart' + Math.random()" width="100%" height="100%" />
</template><script setup lang="ts">
import Echarts from './ECharts.vue';
import { ref, defineProps, watch } from 'vue';const options = ref();const props = defineProps({cdata: {type: Array,default: () => [],},trendsTooltip: {type: Boolean,default: false,},width: {type: String,default: '100%',},height: {type: String,default: '300px',},
});watch(() => props.cdata,(newVal, oldValue) => {if (newVal.length === 0) return;options.value = {tooltip: {trigger: 'item',confine: true,},grid: {top: 10,bottom: 10,left: 10,right: 10,containLabel: true,},legend: false,series: [{type: 'pie',radius: '50%',data: newVal,emphasis: {itemStyle: {shadowBlur: 10,shadowOffsetX: 0,shadowColor: 'rgba(0, 0, 0, 0.5)',},},},],};},{ deep: true, immediate: true }
);
</script>

Index.vue

<template><div class="wrap"><Exampleid="leftMiddleChart":cdata="[{ value: 1048, name: '未开工' },{ value: 735, name: '进行中' },{ value: 580, name: '已完工' },]":trendsTooltip="true"/></div>
</template><script setup lang="ts">
import { defineAsyncComponent } from 'vue';// 引入组件
const Example= defineAsyncComponent(() => import('./Example.vue'));</script><style lang="scss" scoped>
.wrap {width: 800px;height: 600px;overflow: hidden;
}
</style>

这篇关于Vue3 封装ECharts 组件 抽离复用 包含图表随着窗口宽高变化而变化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/844560

相关文章

C#高效实现在Word文档中自动化创建图表的可视化方案

《C#高效实现在Word文档中自动化创建图表的可视化方案》本文将深入探讨如何利用C#,结合一款功能强大的第三方库,实现在Word文档中自动化创建图表,为你的数据呈现和报告生成提供一套实用且高效的解决方... 目录Word文档图表自动化:为什么选择C#?从零开始:C#实现Word文档图表的基本步骤深度优化:C

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

SpringBoot+Vue3整合SSE实现实时消息推送功能

《SpringBoot+Vue3整合SSE实现实时消息推送功能》在日常开发中,我们经常需要实现实时消息推送的功能,这篇文章将基于SpringBoot和Vue3来简单实现一个入门级的例子,下面小编就和大... 目录前言先大概介绍下SSE后端实现(SpringBoot)前端实现(vue3)1. 数据类型定义2.

JavaWeb 中的 Filter组件详解

《JavaWeb中的Filter组件详解》本文详细介绍了JavaWeb中的Filter组件,包括其基本概念、工作原理、核心接口和类、配置方式以及常见应用示例,Filter可以实现请求预处理、响应后... 目录JavaWeb 中的 Filter 详解1. Filter 基本概念1.1 什么是 Filter1.

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A

前端Visual Studio Code安装配置教程之下载、汉化、常用组件及基本操作

《前端VisualStudioCode安装配置教程之下载、汉化、常用组件及基本操作》VisualStudioCode是微软推出的一个强大的代码编辑器,功能强大,操作简单便捷,还有着良好的用户界面,... 目录一、Visual Studio Code下载二、汉化三、常用组件1、Auto Rename Tag2

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多