vue3+ts+vite项目引入echarts,vue3项目echarts组件封装

news2025/1/7 9:41:49

概述

技术栈:Vue3 + Ts + Vite + Echarts
简介: 图文详解,教你如何在Vue3项目中引入Echarts封装Echarts组件,并实现常用Echarts图例


文章目录

  • 概述
  • 一、先看效果
      • 1.1 静态效果
      • 1.2 动态效果
  • 二、话不多数,引入 Echarts
      • 2.1 安装 Echarts
      • 2.2 main.ts 中引入
      • 2.3 Echarts 组件封装
  • 三、使用
      • 3.1 柱状图
      • 3.2 圆环图
      • 3.3 词云图
      • 3.4 雷达图
  • 四、创作不易,点赞收藏不迷路!!!


一、先看效果

1.1 静态效果

在这里插入图片描述

1.2 动态效果

请添加图片描述


二、话不多数,引入 Echarts

2.1 安装 Echarts

npm:

npm i echarts --save

pnpm:

pnpm i echarts --save

2.2 main.ts 中引入

//引入echarts
import * as echarts from 'echarts';
app.config.globalProperties.$echarts = echarts;

2.3 Echarts 组件封装

/src/components/ReEcharts/index.vue 文件中写入如下代码

<script setup lang="ts">
import { ECharts, EChartsOption, init } from 'echarts';
import { ref, watch, onMounted, onBeforeUnmount } from 'vue';

// 定义props
interface Props {
	width?: string;
	height?: string;
	option: EChartsOption;
}
const props = withDefaults(defineProps<Props>(), {
	width: '100%',
	height: '100%',
	option: () => ({})
});

const myChartsRef = ref<HTMLDivElement>();
let myChart: ECharts;
// eslint-disable-next-line no-undef
let timer: string | number | NodeJS.Timeout | undefined;

// 初始化echarts
const initChart = (): void => {
	if (myChart !== undefined) {
		myChart.dispose();
	}
	myChart = init(myChartsRef.value as HTMLDivElement);
	// 拿到option配置项,渲染echarts
	myChart?.setOption(props.option, true);
};

// 重新渲染echarts
const resizeChart = (): void => {
	timer = setTimeout(() => {
		if (myChart) {
			myChart.resize();
		}
	}, 500);
};

onMounted(() => {
	initChart();
	window.addEventListener('resize', resizeChart);
});

onBeforeUnmount(() => {
	window.removeEventListener('resize', resizeChart);
	clearTimeout(timer);
	timer = 0;
});

watch(
	props.option,
	() => {
		initChart();
	},
	{
		deep: true
	}
);
</script>

<template>
	<div ref="myChartsRef" :style="{ height: height, width: width }" :option="option" />
</template>

三、使用

3.1 柱状图

实现效果:
在这里插入图片描述

全量代码:

<script setup lang="ts">
import { reactive } from 'vue';
import Echarts from '@/components/ReEcharts/index.vue';

const option = reactive({
	tooltip: {
		trigger: 'axis',
		axisPointer: {
			type: 'shadow',
			label: {
				show: true
			}
		}
	},
	grid: {
		left: '4%',
		top: '15%',
		right: '4%',
		bottom: '10%'
	},
	legend: {
		data: ['昨日总人数', '今日实时人数'],
		top: '4%',
		color: '#1FC3CE',
		fontSize: 14,
		selected: { 昨日使用率: false } // 不需要显示的设置为false
	},
	xAxis: {
		data: [
			'会议室1',
			'会议室2',
			'会议室3',
			'会议室4',
			'会议室5',
			'会议室6',
			'会议室7',
			'会议室8',
			'会议室9'
		],
		axisLine: {
			show: true, //隐藏X轴轴线
			lineStyle: {
				color: '#eee',
				width: 1
			}
		},
		axisTick: {
			show: true, //隐藏X轴刻度
			alignWithLabel: true
		},
		axisLabel: {
			show: true,
			color: '#333', //X轴文字颜色
			fontSize: 14
		}
	},
	yAxis: [
		{
			type: 'value',
			name: '人数',
			nameTextStyle: {
				color: '#333',
				fontSize: 14
			},
			splitLine: {
				show: true,
				lineStyle: {
					width: 1,
					color: '#eee'
				}
			},
			axisTick: {
				show: false
			},
			axisLine: {
				show: false
			},
			axisLabel: {
				show: true,
				color: '#333',
				fontSize: 14
			}
		}
	],
	series: [
		{
			name: '昨日总人数',
			type: 'bar',
			barWidth: 18,
			itemStyle: {
				color: {
					type: 'linear',
					x: 0, // 右
					y: 1, // 下
					x2: 0, // 左
					y2: 0, // 上
					colorStops: [
						{
							offset: 0,
							color: '#F89898' // 0% 处的颜色
						},
						{
							offset: 1,
							color: '#F56C6C' // 100% 处的颜色
						}
					]
				}
			},
			data: [24, 45, 43, 35, 76, 154, 86, 42, 68]
		},
		{
			name: '今日实时人数',
			type: 'bar',
			barWidth: 18,
			itemStyle: {
				color: {
					type: 'linear',
					x: 0, // 右
					y: 1, // 下
					x2: 0, // 左
					y2: 0, // 上
					colorStops: [
						{
							offset: 0,
							color: '#52A7FF' // 0% 处的颜色
						},
						{
							offset: 1,
							color: '#409EFF' // 100% 处的颜色
						}
					]
				}
			},
			data: [133, 23, 114, 67, 89, 35, 67, 96, 90]
		}
	]
});
</script>

<template>
	<div :style="{ width: '1230px', height: '350px' }">
		<Echarts :option="option" />
	</div>
</template>

3.2 圆环图

实现效果:
在这里插入图片描述
全量代码:

<script setup lang="ts">
import { reactive } from 'vue';
import Echarts from '@/components/ReEcharts/index.vue';

const pieData = reactive([
	{
		name: '大一',
		value: 2100
	},
	{
		name: '大二',
		value: 2502
	},
	{
		name: '大三',
		value: 3156
	}
]);

const option = reactive({
	color: ['#18F6F8', '#288CFC', '#FFD91A'],
	legend: {
		top: '10px',
		icon: 'circle',
		color: '#555',
		itemWidth: 10,
		itemHeight: 10
	},
	tooltip: {
		confine: true,
		trigger: 'item',
		formatter: '{b} : {c}'
	},
	series: [
		{
			avoidLabelOverlap: false,
			type: 'pie',
			roseType: 'area', // 玫瑰图
			center: ['50%', '50%'],
			radius: ['30%', '60%'],
			label: {
				formatter: '{b}\n-------------\n{d}%\t{c}',
				fontSize: 16
			},
			labelLine: {
				length: 10,
				length2: 30
			},
			data: pieData
		}
	]
});
</script>

<template>
	<div :style="{ width: '568px', height: '360px' }">
		<Echarts :option="option" />
	</div>
</template>


3.3 词云图

实现效果:
在这里插入图片描述
全量代码:

<script setup lang="ts">
import { reactive } from 'vue';
import Echarts from '@/components/ReEcharts/index.vue';

let valueList = [30, 50, 60, 65, 70, 80, 90, 100, 120];
let colorList = ['#FAAD14', '#13C2C2', '#14A8FF', '#23D688', '#397EF0'];
let fontSizeList = [12, 14, 16, 18];
let data = [];

let nameList = reactive([
	'Vue3.0',
	'Pinia',
	'Echarts',
	'Element-Plus',
	'axios',
	'Vite',
	'Pure-Admin',
	'Vitality',
	'Husky'
]);
nameList.forEach((item, index) => {
	let valueIndex = index % valueList.length;
	let colorIndex = index % colorList.length;
	let fontSizeIndex = index % fontSizeList.length;

	data.push({
		name: item,
		value: valueList[valueIndex],
		label: {
			color: colorList[colorIndex],
			fontSize: fontSizeList[fontSizeIndex]
		}
	});
});

const option = reactive({
	color: colorList,
	graphic: [
		{
			id: 'baPng',
			type: 'image',
			left: 'center',
			top: 'center',
			style: {
				image:
					'',
				width: '400',
				height: '400'
			}
		}
	],
	series: [
		{
			type: 'graph',
			layout: 'force',
			force: {
				repulsion: 85, // 节点之间的斥力因子
				edgeLength: 85, //边的两个节点之间的距离
				layoutAnimation: true,
				friction: 0.3
			},
			roam: false,
			symbol: '',
			symbolSize: 0,
			label: {
				show: true,
				color: 'auto'
			},
			draggable: false,
			data: data
		}
	]
});
</script>

<template>
	<div :style="{ width: '568px', height: '360px' }">
		<Echarts :option="option" />
	</div>
</template>


3.4 雷达图

实现效果:
在这里插入图片描述

全量代码:

<script setup lang="ts">
import { reactive } from 'vue';
import Echarts from '@/components/ReEcharts/index.vue';

function contains(arr: string | any[], val: any) {
	var i = arr.length;
	while (i--) {
		if (arr[i].name === val) {
			return i;
		}
	}
	return false;
}

let list = [
	{
		name: '北方',
		max: 100
	},
	{
		name: '西北',
		max: 100
	},
	{
		name: '西方',
		max: 100
	},
	{
		name: '西南',
		max: 100
	},
	{
		name: '东方',
		max: 100
	},
	{
		name: '东南',
		max: 100
	}
];
let data1 = [60, 60, 65, 60, 70, 40];

const option = reactive({
	backgroundColor: '#FFFFFF',
	tooltip: {
		show: true,
		trigger: 'item',
		formatter: (data: { seriesName: any; seriesIndex: number; value: any[] }) => {
			// console.log(data.seriesIndex);
			var tip = data.seriesName;
			let tmpData: number[] = [];
			if (data.seriesIndex === 0) {
				tmpData = data1;
			}
			console.log(tmpData);
			data.value.forEach((item: any, index: string | number) => {
				tip += '<div>';
				tip += '<div>' + list[index].name + ': ' + tmpData[index] + '</div>';
				tip += '</div>';
			});
			return tip;
		}
	},
	radar: {
		axisName: {
			color: '#2273DA',
			fontSize: 16,
			rich: {
				a: {
					fontSize: 16,
					color: '#ACD3FF'
					// padding: [0, 0, 8, 0]
				},
				b: {
					fontSize: 16,
					color: '#ACD3FF'
				}
			},
			formatter: (a: any) => {
				let i = contains(list, a); // 处理对应要显示的样式
				return `{a| ${a}}{b|(${data1[i]})}`;
			}
		},
		center: ['50%', '50%'],
		radius: '70%',
		startAngle: 90,
		splitNumber: 4,
		splitArea: {
			areaStyle: {
				color: ['rgba(50, 72, 130, 0.7)', 'rgba(50, 72, 130, 0.5)', 'rgba(50, 72, 130, 0.6)']
			}
		},
		axisLabel: {
			show: false
		},
		axisLine: {
			show: false
		},
		splitLine: {
			show: true,
			lineStyle: {
				color: 'rgba(50, 72, 130, 0.4)'
			}
		},
		indicator: list
	},
	series: [
		{
			axisName: '数据',
			type: 'radar',
			symbol: 'circle',
			symbolSize: 10,
			itemStyle: {
				color: 'rgba(19, 173, 255, 1)',
				borderColor: 'rgba(19, 173, 255, 0.4)',
				borderWidth: 10
			},

			label: {
				show: true,
				formatter: (params: { value: any }) => {
					return params.value;
				},
				color: '#fff'
			},
			areaStyle: {
				color: {
					type: 'linear',
					x: 0, // 右
					y: 1, // 下
					x2: 0, // 左
					y2: 0, // 上
					colorStops: [
						{
							offset: 0,
							color: 'rgba(82, 247, 242, 1)'
						},
						{
							offset: 1,
							color: 'rgba(65, 105, 213, 1)'
						}
					]
				}
			},
			data: [
				{
					value: data1
				}
			]
		}
	]
});
</script>

<template>
	<div :style="{ width: '568px', height: '360px' }">
		<Echarts :option="option" />
	</div>
</template>

四、创作不易,点赞收藏不迷路!!!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Polarion创建项目

创建项目添加用户删除用户项目访问

消息中间件(一)

文章目录 消息中间件什么是中间件&#xff1f;为什么使用MQ&#xff1f;应用场景&#xff1f; JMS和AMQPJMSAMQPJMS和AMQP的区别 消息队列产品 消息中间件 什么是中间件&#xff1f; MQ全称为Message Queue&#xff0c;消息队列是应用程序和应用程序之间的通信方法。 中间件是…

大模型优化:RAG还是微调?

引言 随着人们对大型语言模型 (LLM) 的兴趣激增&#xff0c;许多开发人员和组织正忙于利用其能力构建应用程序。然而&#xff0c;当开箱即用的预训练LLM没有按预期或希望执行时&#xff0c;如何提高LLM申请的性能的问题。最终我们会问自己&#xff1a;我们应该使用检索增强生成…

Vue中如何实现城市3D分布图

cityfenbu.vue <template><div ><el-card class"seriesmap-box-card"><div slot"header" class"clearfix"><span>城市分布图 (点击可下钻到县)</span></div><div><div class"series-ma…

不出意外的话,2023年是AI大模型元年

这两天听的最多的新闻莫过于&#xff0c;谁谁谁&#xff08;AI 大模型&#xff09;面向全社会开放使用&#xff0c;文心一言、WPSAI、讯飞星火、百川智能等等&#xff0c;2023年&#xff0c;AI大模型注定在历史上增添了浓妆淡抹的一幕&#xff0c;未来 AI 将与各个软件应用如影…

RPC协议交互流程

文章目录 RPC特性RPC实现RPC交互流程RPC交互时序图RPC交互流程 RPC&#xff08;Remote Procedure Call&#xff0c;远程过程调用&#xff09; 是一种分布式计算的通信协议和编程模型&#xff0c;用于不同计算机或进程之间进行远程通信。它允许一个计算机程序&#xff08;通常是…

TOWE新能源电动汽车充电延长线,解决户外充电距离过短烦恼

随着新能源汽车市场的日益繁荣&#xff0c;越来越多的车主开始关注充电设备的便利性。为了满足广大车主的充电需求&#xff0c;同为科技&#xff08;TOWE&#xff09;荣誉推出全新16A三芯大功率新能源电动汽车充电延长电源线。这款产品采用优质材料&#xff0c;结构合理&#x…

@Value,@Autowired,@Qualifier

Value 当属性的类型是简单类型时&#xff0c;可以使用Value注解进行注入。 package com.powernode.spring6.bean4;import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component;Component public class User {Value(value …

NASM编译器之下载安装使用

NASM的下载和安装 每种处理器都可能会有自己的汇编语言编译器&#xff0c;而对于同一款处理器来说&#xff0c;针对不同的平台(比如Windows和Linux&#xff09;&#xff0c;也会有不同版本的汇编语言编译器。 现存的汇编语言编译器有多种&#xff0c;用得比较多的有 MASM、FA…

如何加快跨国传输大文件的速度?

在当今的信息化社会&#xff0c;数据已经成为各行各业的重要资产&#xff0c;而数据的传输和交换则是数据价值的体现。在很多场景中&#xff0c;我们需要跨国传输大文件&#xff0c;比如政府、军队、金融、医疗等涉密行业&#xff0c;或者跨国、跨区域的企业合作。然而&#xf…

浅谈安科瑞ADL400系列导轨电能表在沙特电力物联网平台中的应用

1.项目概述&#xff1a;Project Overview 沙特客户需要对小区住宅&#xff0c;及商铺进行用户端电能计量&#xff0c;管理。需要安装三相交流电表监测电能数据&#xff0c;并上传到后台系统进行统一监控管理。安科瑞推荐电力物联网平台&#xff0c;可以通过云端界面和APP查看不…

Python中文字体包下载经历(经验分享)

故事背景 python解释器需要中文字体包&#xff0c;我找了半天网络上的中文字体包&#xff0c;每一个过程都非常繁琐。 都是先注册&#xff0c;在安装他们的软件&#xff0c;软件安装好后下载&#xff0c;下载的还不是字体包格式的文件&#xff0c;反正就是在欺负小白。 解决…

浅谈能源汽车下乡充电桩建设优化建议及解决方案

1.趋势分析 新能源汽车下乡已经成为提振汽车市场表现、推动汽车行业发展的重要措施。国家发改委日前也提出&#xff0c;汽车消费是支撑消费的“大头”&#xff0c;将加快推进充电桩和城市停车设施建设&#xff0c;大力推动新能源汽车下乡&#xff0c;鼓励汽车企业开发更适宜县…

若依集成mybatisplus、兼容旧分页【亲测有效】

这里写目录标题 一 修改pom文件最外层的pom.xml增加如下配置common模块的pom文件加入如下配置 二 framework模块的config包增加两个类MybatisPlusPageConfigurerSqlFilterArgumentResolver 三 全局搜索com.ruoyi.framework.config.MyBatisConfig类&#xff0c;将此类注释掉四 y…

excel表中复制粘贴有隐藏行的情况

一、原始数据&#xff0c;没有任何隐藏的情况&#xff1a; 二、隐藏3、4行&#xff1a; 这种情况下&#xff1a; 三、我想复制粘贴出可见的内容&#xff0c;全选&#xff0c;ctrlc复制 四、ctrlv粘贴到别处&#xff0c;结果却是 发现隐藏的行也被复制粘贴出来了。并不是我们想…

求求你,别再用 Mybatis Plus 的伪批量新增了!

前言 大家好&#xff0c;我是小哈~ 本文节选自小哈写的《Mybatis Plus 教程》中的批量新增一节&#xff0c;旨在帮助大家如何在 Mybatis Plus 中&#xff0c;实现 MySQL 真实的批量新增&#xff0c;而不是伪批量新增。 最近&#xff0c;小哈在带小伙伴做 前后端分离项目&#x…

2023年MySQL-8.0.34保姆级安装教程

重点放前面&#xff1a;演示环境为windows环境。 MySQL社区版本安装教程如下&#xff1a; 一、MySQL安装包下载二、安装配置设置三、配置环境变量 大体分为3个步骤&#xff1a;①安装包的下载&#xff1b;②安装配置设置&#xff1b;③配置环境变量 一、MySQL安装包下载 下载官…

界面长的像算抄袭吗?

昨晚&#xff0c;在GitHub和X上&#xff0c;被一次疑似抄袭的问题刷了一会儿屏&#xff0c;主要是下面这个issue&#xff1a; 相关的开源项目是小米的米效&#xff0c;英文名&#xff1a;Mone。一个以微服务为中心的一站式企业协同研发平台。支持公有云、私有云、混合云等多种部…

Redis Cluster集群运维与核心原理剖析

Redis集群方案比较 哨兵模式 在redis3.0以前的版本要实现集群一般是借助哨兵sentinel工具来监控master节点的状态&#xff0c;如果master节点异常&#xff0c;则会做主从切换&#xff0c;将某一台slave作为master&#xff0c;哨兵的配置略微复杂&#xff0c;并且性能和高可用性…

2023/09/07 c++qt day2

#include <iostream>using namespace std; //封装一个学生类 struct stu { private://存放学生的成绩int stu_score[256];//记录学生个数int stu_num; public://用于设置学生个数void setNum(){cout<<"请输入学生的个数"<<" ";cin>&g…