【web应用】在 Vue 3 中实现饼图:使用 Chart.js实现饼图显示数据分析结果

文章目录

  • 前言
  • 一、准备工作
  • 二、实现饼图组件
  • 三、关键点解析
  • 四、实现效果
  • 总结


前言

在现代 Web 应用中,数据可视化是不可或缺的一部分。无论是展示统计信息还是监控关键指标,图表都能帮助用户更直观地理解数据。在 Vue 3 项目中,我们可以使用 Chart.js 这个强大且灵活的库来创建各种类型的图表。本文将介绍如何在 Vue 3 中使用 Chart.js 实现一个简单的饼图,展示人员出勤情况。

一、准备工作

首先,确保你的 Vue 3 项目已经初始化。如果还没有,可以使用 Vue CLI 快速创建一个新项目:

npm install -g @vue/cli
vue create my-vue-app
cd my-vue-app

接下来,安装 Chart.js:

npm install chart.js

二、实现饼图组件

我们将创建一个组件来展示人员出勤情况的饼图。以下是一个完整的实现示例:

<template><div class="app-container home"><!-- 人员信息模块 --><div class="module personnel-info"><h3>人员信息</h3><div class="content"><div class="chart-place"><canvas id="attendanceChart" width="300" height="300"></canvas></div><div class="personnel-stats"><div class="stat-item"><span>出勤人数</span><strong>20</strong></div><div class="stat-item"><span>总人数</span><strong>25</strong></div><div class="stat-item"><span>出勤率</span><strong>80%</strong></div></div></div></div></div>
</template><script setup>
import { onMounted } from 'vue';
import Chart from 'chart.js/auto';onMounted(() => {const ctx = document.getElementById('attendanceChart').getContext('2d');new Chart(ctx, {type: 'pie',data: {labels: ['出勤', '未出勤'],datasets: [{data: [20, 5],backgroundColor: ['#5470C6', '#91CC75'], // 使用转换后的十六进制颜色hoverBackgroundColor: ['#3A8EFD', '#7CB342'],borderWidth: 0 // 去掉白色边框}]},options: {responsive: false, // 禁用响应式,以便手动设置大小maintainAspectRatio: false, // 禁用宽高比保持plugins: {legend: {position: 'top', // 将图例放置在饼图上方labels: {color: '#A6CAF4', // 图例文字颜色font: {size: 14 // 设置图例文字的大小}}}}}});
});
</script><style scoped lang="scss">
.app-container {padding: 20px;background-color: transparent;color: #fff;
}.module {background-color: transparent;border-radius: 5px;padding-top: 5px;padding-left: 45px;padding-right: 30px;flex: 1;h3 {color: #A6CAF4;padding-bottom: 8px;margin-bottom: 8px;font-size: 22px;font-weight: bold;display: inline-block;background-image: url('@/assets/images/光环2.png');background-size: contain;background-repeat: no-repeat;padding-left: 5px;background-position: left 20px;}
}.personnel-info {background-image: url('@/assets/images/组合 64.png');background-size: 100% 100%;background-repeat: no-repeat;background-position: center;position: absolute;top: 70px;left: 30px;width: 500px;height: 365px;.content {display: flex;}.chart-place {display: flex;height: 250px;width: 60%;justify-content: center;align-items: center;}.personnel-stats {display: flex;flex-wrap: wrap;width: 40%;flex-direction: column;justify-content: center;align-items: stretch;.stat-item {width: 100%;margin-bottom: 20px;background-color: rgba(0, 51, 102, 0.5);border-radius: 8px;padding: 9px;span {display: block;color: #A6CAF4;font-size: 17px;margin-bottom: 5px;text-align: center;}strong {display: block;font-size: 25px;color: #00b7ee;text-align: center;}}}
}
</style>

三、关键点解析

  1. 安装和导入 Chart.js

    • 使用 npm install chart.js 安装库。
    • 在组件中使用 import Chart from 'chart.js/auto'; 导入。
  2. 设置饼图的基本配置

    • 使用 type: 'pie' 指定图表类型为饼图。
    • data 中定义 labelsdatasets,其中 datasets 包含数据值和样式配置。
  3. 调整饼图外观

    • 使用 backgroundColor 设置每个部分的背景颜色。
    • 设置 borderWidth: 0 去掉数据项之间的白色边框。
  4. 配置图例

    • 使用 plugins.legend.position: 'top' 将图例放置在饼图上方。
    • 使用 labels.font.size 调整图例文字的大小。
  5. 样式和布局

    • 使用 SCSS 定义组件的样式,确保图表和统计信息的布局合理。

四、实现效果

在这里插入图片描述

总结

在 Vue 3 中使用 Chart.js 创建饼图是一个简单而有效的方法来可视化数据。通过配置选项,你可以轻松调整图表的外观和行为,以满足你的需求。希望本文能帮助你更好地理解如何在 Vue 3 项目中集成和使用 Chart.js。

如果你对 Chart.js 的更多功能和配置选项感兴趣,可以查阅 Chart.js 官方文档。

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

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

相关文章

分页数据不准问题分析与解决

大纲 &#x1f4d6; 1、场景 &#x1fab5;2、原因 &#x1f525;3、解决方式&#xff1a;游标分页 &#x1f4cf;4、一点思考&#x1f4a1;5、全表查询的优化思路 &#x1f345; 记录一个分页不准的问题 1、场景 &#x1fab5; 调用一个第三方List接口&#xff08;带分页&am…

MyBatis原理剖析(三)--加载配置文件

下面我们正式进入mybatis的源码学习&#xff0c;之前我们已经了解过mybatis中通过配置文件来保证与数据库的交互。配置文件分为核心配置文件和映射配置文件&#xff0c;核心配置文件的主要作用就是加载数据库的一些配置信息而映射配置文件则是执行对应的sql语句。同时核心配置文…

C++(运算符重载)

一.友元 C中使用关键字friend可以在类外访问所有的成员&#xff0c;包括私有成员&#xff08;之前提到过封装的核心思想是隐藏内部实现细节&#xff0c;通过公共接口控制访问&#xff09;&#xff0c;所以友元可以突破封装的限制访问数据&#xff0c;盲目使用会导致程序稳定性…

XR-RokidAR-UXR3.0-Draggable 脚本解析

using System.Collections.Generic; using Rokid.UXR.Utility; using UnityEngine; using UnityEngine.EventSystems;namespace Rokid.UXR.Interaction {/// <summary>/// Draggable 拖拽组件/// </summary>// [RequireComponent(typeof(RayInteractable))]public …

GitHub 趋势日报 (2025年06月17日)

&#x1f4ca; 由 TrendForge 系统生成 | &#x1f310; https://trendforge.devlive.org/ &#x1f310; 本日报中的项目描述已自动翻译为中文 &#x1f4c8; 今日获星趋势图 今日获星趋势图 1022 anthropic-cookbook 986 awesome-llm-apps 910 fluentui-system-icons 754 r…

NodeJS的中间件是什么

说简单一点&#xff0c;中间件就是在你的请求和业务逻辑之间做一层拦截。 在 Node.js 中&#xff0c;中间件&#xff08;Middleware&#xff09; 是一种函数&#xff0c;它在 请求&#xff08;Request&#xff09;到达路由处理器之前&#xff0c;或在 响应&#xff08;Respons…

MCAL学习(6)——诊断、DCM

1.诊断概述 汽车诊断就是通过汽车总线&#xff08;CAN LIN Eth&#xff09;来进行诊断会话&#xff0c;大部分通过CAN总线通讯进行请求与响应。 1.诊断分层 DCM内部支持UDS服务和OBD服务&#xff08;排放&#xff0c;动力&#xff09;。 以统一诊断服务UDS为例&#xff0c;应…

kafka-生产者-(day-4)

day-3 BufferPool 产生原因&#xff1a;ByteBuffer的创建和释放都是比较耗费资源的&#xff0c;为了实现内存的高效利用&#xff0c;产生了他。他会对特定大小的ByteBuffer进行管理 BufferPool的字段 free:是一个ArrayDeque队列&#xff0c;缓存指定大小的ByteBuffer对象Re…

java 验证ip是否可达

默认IP的设备已开放ping功能 代码 public class PingTest {public static void main(String[] args) throws Exception {String ip "192.168.21.101";boolean reachable InetAddress.getByName(ip).isReachable(3000);System.out.println(ip (reachable ? &quo…

LeetCode 2187.完成旅途的最少时间

题目&#xff1a; 给你一个数组 time &#xff0c;其中 time[i] 表示第 i 辆公交车完成 一趟旅途 所需要花费的时间。 每辆公交车可以 连续 完成多趟旅途&#xff0c;也就是说&#xff0c;一辆公交车当前旅途完成后&#xff0c;可以 立马开始 下一趟旅途。每辆公交车 独立 运…

永磁同步电机无速度算法--基于正切函数锁相环的滑模观测器

最近在学习锁相环&#xff0c;后续会记录一下了解到的几种PLL。 一、原理介绍 传统锁相环控制框图如下所示 在电机正转时&#xff0c;传统锁相环可以实现很好的转速和转子位置估计&#xff0c;但是当电机反转&#xff0c;反电动势符号发生变化&#xff0c;系统估计转子位置最…

Vim-vimrc 快捷键映射

Vim-vimrc 快捷键映射 文章目录 Vim-vimrc 快捷键映射Leader 键快捷键映射&#xff1a;插入特定字符插入 --插入 ##插入 解释Leader键设置快速插入分隔线 Leader 键 我们还将 , 设置为 Leader 键&#xff0c;使得其他快捷键映射更加简洁。 let mapleader ","快捷键…

SylixOS armv7 任务切换

SylixOS 操作系统下&#xff0c;任务切换可以分为两种 中断退出时&#xff0c;执行的任务切换&#xff08;_ScheduleInt&#xff09;内核退出时&#xff0c;执行的任务切换&#xff08;_Schedule&#xff09; 下面分别讲讲这两种任务切换 1、中断退出时任务切换 关于 ARM 架…

Java 自定义异常:如何优雅地处理程序中的“业务病”?

&#x1f525;「炎码工坊」技术弹药已装填&#xff01; 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、从一个真实场景开始&#xff1a;银行转账系统的困境 假设你正在开发一个银行转账系统&#xff0c;当用户尝试转账时可能出现以下问题&#xff1a; 转…

【JAVA】【Stream流】

1. filter操作 filter()方法用于根据给定的条件过滤列表中的元素&#xff0c;仅保留满足条件的项。 List<Integer> list Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8);List<Integer> res list.stream().filter(a -> a % 2 0).collect(Collectors.toList());for(I…

四、Redis实现限流

简介&#xff1a; 限流算法在分布式领域是一个经常被提起的话题&#xff0c;当系统的处理能力有限时&#xff0c;如何阻止计划外的请求继续对系统施压。 系统要限定用户的某个行为在指定的时间里只能允许发生 N 次&#xff0c;如何使用 Redis 的数据结构来实现这个限流的功能&a…

基于Geotools的两条道路相交并根据交点形成新路线实战-以OSM数据为例

目录 前言 一、需求场景及分解 1、需求场景 2、需求应用 二、需求实现 1、加载路网数据 2、获取道路信息 3、相交点求解 4、生成新道路 5、结果可视化 三、总结 前言 在当今数字化迅速发展的时代&#xff0c;地理空间数据的处理与分析已成为众多领域不可或缺的关键技…

goland有基础速通(需要其它编程语言基础)

tip: 无论是变量、方法还是struct的访问权限控制都是通过命名控制的&#xff0c;命名的首字母是大写就相当于java中的public&#xff0c;小写的话就是private&#xff0c;&#xff08;private只有本包可以访问&#xff09; 1 go的变量声明 普通变量 特点&#xff1a; 变量类…

量化面试绿皮书:19. 相关系数

文中内容仅限技术学习与代码实践参考&#xff0c;市场存在不确定性&#xff0c;技术分析需谨慎验证&#xff0c;不构成任何投资建议。 19. 相关系数 假设有三个随机变量x、y和z。 x与y之间的相关系数为0.8&#xff0c;x与z之间的相关系数也是0.8。 Q: 那么y与z之间的最大相关…

新生活的开启:从 Trae AI 离开后的三个月

很久没有写文章了&#xff0c;想借着入职新公司一个月的机会&#xff0c;和大家唠唠嗑。 离职 今年2月份我从字节离职了&#xff0c;结束了四年的经历&#xff0c;当时离开的核心原因是觉得加班时间太长了&#xff0c;平均每天都要工作15&#xff0c;16个小时&#xff0c;周末…