【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
英文地址,請注明出處:http://en.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;周末…