Vue3 實現 Excel 文件導入導出功能

在Vue 3中實現Excel文件的導入和導出功能,你可以使用一些流行的JavaScript庫,如SheetJS(也稱為xlsx)來處理Excel文件。以下是實現這一功能的基本步驟:

1. 安裝SheetJS

首先,你需要安裝xlsx庫。在你的Vue項目中,可以通過npm或yarn來安裝:

npm install xlsx
# 或者
yarn add xlsx

2. 導入和導出Excel文件

導入Excel文件

你可以使用一個文件輸入(<input type="file">)來讓用戶選擇文件,然后讀取文件內容。

<template><div><input type="file" @change="handleFileUpload" /><button @click="exportExcel">導出Excel</button></div>
</template><script setup>
import * as XLSX from 'xlsx';
import { ref } from 'vue';const data = ref([]); // 存儲Excel數據const handleFileUpload = (event) => {const files = event.target.files;if (files.length === 0) return;const file = files[0];const reader = new FileReader();reader.onload = (e) => {const data = new Uint8Array(e.target.result);const workbook = XLSX.read(data, { type: 'array' });const firstSheetName = workbook.SheetNames[0];const worksheet = workbook.Sheets[firstSheetName];const jsonData = XLSX.utils.sheet_to_json(worksheet);data.value = jsonData; // 更新data為導入的Excel數據};reader.readAsArrayBuffer(file);
};
</script>
導出Excel文件

要導出數據到Excel文件,你可以使用XLSX.utils.book_new()創建一個新的工作簿,然后添加一個工作表并寫入數據。最后,將工作簿轉換為二進制數據,并使用URL.createObjectURL()創建一個下載鏈接。

<script setup>
import * as XLSX from 'xlsx';
import { ref } from 'vue';const data = ref([ /* 示例數據 */ ]); // 示例數據,實際應用中應從用戶導入的數據中獲取或從其他來源獲取const exportExcel = () => {const ws = XLSX.utils.json_to_sheet(data.value); // 將數據轉換為工作表對象const wb = XLSX.utils.book_new(); // 創建新的工作簿對象XLSX.utils.book_append_sheet(wb, ws, "Sheet1"); // 將工作表添加到工作簿中,命名為"Sheet1"const wbout = XLSX.write(wb, { bookType: 'xlsx', type: 'array' }); // 將工作簿轉換為二進制數據function s2ab(s) { return new Uint8Array(s); } // 輔助函數,將字符串轉換為ArrayBuffer對象saveAs(new Blob([s2ab(wbout)],{type:"application/octet-stream"}), "export.xlsx"); // 使用FileSaver.js保存文件(需要額外安裝)
};
</script>

3. 使用FileSaver庫來保存文件(可選)

如果你需要創建一個下載鏈接并觸發下載,可以使用FileSaver庫。首先安裝它:

npm install file-saver
# 或者
yarn add file-saver

然后在你的代碼中引入并使用它:

import { saveAs } from 'file-saver'; // 從file-saver導入saveAs函數

確保在導出函數中使用saveAs來觸發下載:

saveAs(new Blob([s2ab(wbout)],{type:"application/octet-stream"}), "export.xlsx"); // 使用FileSaver.js保存文件(需要額外安裝)

這樣,用戶就可以通過點擊按鈕來導出Excel文件了。通過上述步驟,你可以在Vue 3應用中實現Excel文件的導入和導出功能。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/89881.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/89881.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/89881.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

CS231n-2017 Lecture2圖像分類筆記

圖像分類問題定義&#xff1a;在已有固定的分類標簽集合的前提下&#xff0c;能夠對輸入的圖像進行識別處理&#xff0c;從集合中找到該圖像所對應的標簽。對于計算機而言&#xff0c;圖像并非直觀的圖像&#xff0c;而是一個的像素集合&#xff0c;對于每個像素&#xff0c;其…

Typecho博客Ajax評論功能實現全攻略

文章目錄 Typecho實現Ajax評論功能的完整指南 引言 一、技術選型與準備工作 1.1 技術棧分析 1.2 環境準備 二、前端實現方案 2.1 基礎HTML結構 2.2 JavaScript處理邏輯 三、后端處理實現 3.1 創建插件處理Ajax請求 3.2 錯誤處理增強 四、安全性考慮 4.1 CSRF防護 4.2 輸入過濾 …

【計算機考研(408)- 數據結構】樹與二叉樹

樹與二叉樹 樹的定義及相關概念 樹是n&#xff08;n≥0&#xff09;個結點的有限集合&#xff0c;n 0時&#xff0c;稱為空樹&#xff0c;這是一種特殊情況。在任意一棵非空樹中應滿足&#xff1a; 1&#xff09;有且僅有一個特定的稱為根的結點。 2&#xff09;當n > 1時…

MacOS:如何利用終端來操作用戶

MacOS&#xff1a;如何利用終端來操作用戶MacOS&#xff1a;如何利用終端來操作用戶1. 創建用戶并賦予管理員權限步驟&#xff1a;2. 取消用戶的管理員權限解釋&#xff1a;3. 查看組成員查看 admin 組成員&#xff1a;查看 users 組成員&#xff1a;4. 其他常見的用戶管理命令…

基于SpringBoot+MyBatis+MySQL+VUE實現的醫療掛號管理系統(附源碼+數據庫+畢業論文+答辯PPT+項目部署視頻教程+項目所需軟件工具)

摘 要 在如今社會上&#xff0c;關于信息上面的處理&#xff0c;沒有任何一個企業或者個人會忽視&#xff0c;如何讓信息急速傳遞&#xff0c;并且歸檔儲存查詢&#xff0c;采用之前的紙張記錄模式已經不符合當前使用要求了。所以&#xff0c;對醫療掛號信息管理的提升&#x…

學成在線項目

黑馬程序員學成在線項目學習過程記錄 解決跨域問題

Shell腳本-grep工具

一、前言在 Linux/Unix 系統中&#xff0c;grep 是一個非常強大且常用的文本搜索工具&#xff0c;它可以幫助我們快速從文件或標準輸入中查找匹配特定模式的內容。無論是查看日志、調試腳本&#xff0c;還是進行自動化數據提取&#xff0c;grep 都扮演著至關重要的角色。本文將…

深入解析Ext2文件系統架構

要在硬盤上存儲文件&#xff0c;必須先將硬盤格式化為特定類型的文件系統。文件系統的主要功能就是組織和管硬盤中的文件。在Linux系統中&#xff0c;最常見的文件系統是Ext2系列&#xff0c;其早期版本為Ext2&#xff0c;后續又發展出Ext3和Ext4。雖然Ext3和Ext4對Ext2進行了功…

商業秘密保護:從法律理論到企業實戰

作者&#xff1a;邱戈龍、柯堅豪深圳商業秘密律師廣東長昊律師事務所在商業競爭中&#xff0c;商業秘密就像企業的"隱形護城河"。從法律角度看&#xff0c;它的保護路徑經歷了三次重要升級&#xff1a;從最初的"合同約定"到后來的"財產保護"&…

AI產品經理面試寶典第36天:AI+旅游以及行業痛點相關面試題的指導

一、AI如何解決旅游行業核心痛點? 面試官提問: "請結合具體案例說明AI在旅游行業的應用價值,以及它如何解決傳統旅游服務的痛點?" 你的回答: 以騰訊"一部手機游云南"為例,AI技術通過四大核心體系重構旅游體驗: 數字身份體系:通過人臉識別與用戶…

【conda】Linux系統中部署Conda環境

目錄 一、安裝 Miniconda 1.1 下載 Miniconda 安裝腳本 1.2 運行安裝腳本 1.3 初始化 Conda&#xff1a; 安裝完成后&#xff0c;初始化 Conda 環境 1.4 驗證安裝 二、設置虛擬環境默認存放路徑&#xff08;可選&#xff09; 三、conda創建虛擬環境 3.1 創建 Conda 環境…

Spring Boot 解決跨域問題

在 Spring Boot 中解決跨域問題&#xff08;CORS&#xff09;主要有三種常用方式&#xff0c;下面詳細說明每種實現方法&#xff1a; 方案一&#xff1a;全局配置&#xff08;推薦&#xff09; 在配置類中實現 WebMvcConfigurer 接口&#xff0c;統一配置所有接口的跨域規則&am…

Softhub軟件下載站實戰開發(十九):軟件信息展示

上一篇文章中我們上線了軟件分離展示&#xff0c;本篇文章我們聚焦軟件信息展示 軟件列表信息展示 點擊一級分類查詢該分類下所以軟件分類切換要有動畫效果分頁支持 核心實現 <transition-grouptag"div"class"software-grid"before-enter"before…

[HDLBits] Cs450/gshare

Branch direction predictor 分支方向預測器 A branch direction predictor generates taken/not-taken predictions of the direction of conditional branch instructions. It sits near the front of the processor pipeline, and is responsible for directing instructio…

[學習] 雙邊帶調制 (DSB) 與單邊帶調制 (SSB) 深度對比

雙邊帶調制 (DSB) 與單邊帶調制 (SSB) 深度對比 文章目錄雙邊帶調制 (DSB) 與單邊帶調制 (SSB) 深度對比**數學原理****調制表達式與頻譜****時域特性****頻域特性****Python 仿真代碼****仿真結果分析****工程應用建議**數學原理 設基帶信號為 m(t)m(t)m(t)&#xff08;帶寬為…

Gitee 提交信息的規范

在使用 git push 命令將代碼推送到 Gitee&#xff08;或任何 Git 平臺&#xff09;時&#xff0c;引號中的信息通常指的是 提交信息&#xff08;Commit Message&#xff09;。提交信息是對本次代碼修改的簡要描述&#xff0c;規范的提交信息有助于團隊協作和版本管理。 Gitee 提…

C 語言經典編程題實戰:從基礎算法到趣味問題全解析

在 C 語言學習過程中&#xff0c;通過實戰編程題鞏固知識點是非常有效的方式。本文整理了一系列經典 C 語言編程題&#xff0c;涵蓋基礎計算、邏輯判斷、圖形打印等多個維度&#xff0c;并附上完整代碼與解析&#xff0c;適合初學者參考學習上機題1.計算n以內所有正奇數的和 ?…

Chapter 3 Design of Switching Power Regulators

Chapter 3 Design of Switching Power Regulators Power Management Techniques for Integrated Circuit Design by Ke-Horng Chen 這本書比較深, 簡單介紹基本概念后, 就直接拋出大段公式和結論, 一章講其他書幾章內容, 適合有一定基礎, 想進一步做電源系統的人查閱. 優點是不…

算法題(176):three states

審題&#xff1a; 本題需要我們找到最佳鋪設道路&#xff0c;將三個國家聯通起來&#xff0c;然后輸出最佳鋪設道路的鋪設數量&#xff0c;若沒有聯通方法則輸出-1 思路&#xff1a; 首先我們正面思考&#xff1a;只需從某個點出發然后搜索到三個國家即可&#xff0c;最后對比所…

BIOS+MBR微內核加載loader程序實現過程

上一篇講到的微內核程序是由BIOS例程自動加載到內存中運行的,而且大小有限,能做的事情有限。我們知道內核程序大小是可以擴展的不能只有512字節,同時在加載運行內核前還需要完成一些必要的實模式下才能做的準備工作。所以單純在實模式下只使用微內核程序是不太夠的,就有了加…