news 2026/4/15 12:24:22

vue导出excel文件

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vue导出excel文件

Vue.js 本身不提供直接导出 Excel 的功能,但可以通过以下几种方式实现:

1.前端导出方案

使用 xlsx 库(推荐)

npm install xlsx # 或 yarn add xlsx
<template> <button @click="exportExcel">导出Excel</button> </template> <script> import * as XLSX from 'xlsx'; export default { data() { return { tableData: [ { name: '张三', age: 25, city: '北京' }, { name: '李四', age: 30, city: '上海' } ] } }, methods: { exportExcel() { // 创建工作簿 const wb = XLSX.utils.book_new(); // 创建工作表 const ws = XLSX.utils.json_to_sheet(this.tableData); // 将工作表添加到工作簿 XLSX.utils.book_append_sheet(wb, ws, 'Sheet1'); // 导出文件 XLSX.writeFile(wb, '用户数据.xlsx'); } } } </script>

使用 exceljs(功能更强大)

npm install exceljs npm install file-saver
import ExcelJS from 'exceljs'; import { saveAs } from 'file-saver'; async exportExcel() { const workbook = new ExcelJS.Workbook(); const worksheet = workbook.addWorksheet('Sheet1'); // 添加表头 worksheet.columns = [ { header: '姓名', key: 'name' }, { header: '年龄', key: 'age' }, { header: '城市', key: 'city' } ]; // 添加数据 this.tableData.forEach(item => { worksheet.addRow(item); }); // 保存文件 const buffer = await workbook.xlsx.writeBuffer(); const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }); saveAs(blob, '用户数据.xlsx'); }

2.使用现成组件

vue-json-excel

npm install vue-json-excel
<template> <download-excel :data="tableData" :fields="jsonFields" name="用户数据.xlsx" > <button>导出Excel</button> </download-excel> </template> <script> import JsonExcel from 'vue-json-excel'; export default { components: { 'download-excel': JsonExcel }, data() { return { tableData: [...], jsonFields: { '姓名': 'name', '年龄': 'age', '城市': 'city' } } } } </script>

3.后端生成方案

如果数据量大或需要复杂格式,建议后端生成:

// 前端调用 exportExcel() { axios({ url: '/api/export/excel', method: 'GET', responseType: 'blob' // 重要:接收文件流 }).then(response => { const blob = new Blob([response.data], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }); const url = window.URL.createObjectURL(blob); const link = document.createElement('a'); link.href = url; link.download = 'data.xlsx'; link.click(); window.URL.revokeObjectURL(url); }); }

4.简单表格导出

exportTable() { const table = document.querySelector('#your-table'); const wb = XLSX.utils.table_to_book(table); XLSX.writeFile(wb, '表格数据.xlsx'); }

注意事项

  1. 数据量大时:建议使用后端导出,避免浏览器内存溢出

  2. 格式化处理:日期、数字等特殊格式需要转换

  3. 样式需求:如需复杂样式,建议使用 exceljs

  4. 兼容性:xlsx 库兼容性较好,支持多种格式

推荐方案

  • 简单场景:使用 xlsx 库

  • 需要样式和复杂功能:使用 exceljs

  • 大数据量:后端生成

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 11:22:27

移动通信无线基站的防雷技术研究

一、基站防雷技术概述 移动通信基站的防雷是保障通信安全的关键环节&#xff0c;涉及直击雷防护、感应雷防护和接地系统三大方面。基站通常建在高处或开阔地带&#xff0c;天线和铁塔易成为雷击目标&#xff0c;一旦遭受雷击&#xff0c;不仅可能损坏设备&#xff0c;还会造成通…

作者头像 李华
网站建设 2026/4/15 12:23:49

跨网聊天自由!Fiora这样用突破地域限制

文章目录前言1.关于Fiora2.安装Docker3.本地部署Fiora4.使用Fiora5.cpolar内网穿透工具安装6.创建远程连接公网地址7.固定Uptime Kuma公网地址前言 Fiora 是一款功能丰富的开源聊天工具&#xff0c;支持一对一私聊、群组聊天&#xff0c;能发送文本、图片、文件、代码等多种消…

作者头像 李华
网站建设 2026/4/15 5:47:33

2500线磁编码器方案:电机反馈系统的新选择

2500线磁编码器方案 电机反馈系统 &#xff0c;用于交直流伺服和步进闭环&#xff0c;替换原来光编方案。 原理图和PCB全套文件 支持电机驱动器&#xff1a;迈信EP100、广数DA98、数控SD200A等 。增量ABZ差分输出&#xff0c;UVW差分输出&#xff0c;2500PPR&#xff0c;Z脉冲宽…

作者头像 李华
网站建设 2026/4/15 5:51:18

抓取cpu持续忙碌状态的方法

一、背景 在一些cpu资源并不是很充足的系统上,往往会出现cpu持续一段时间特别忙碌的情况,cpu持续忙碌是一个很不好的状态,可能会伴随着有些任务的调度时延变大,系统里的一些业务如果要求一定的实时性的话,这时候就会产生问题。 编写一个ko来抓取cpu的忙碌状态是有意义的…

作者头像 李华
网站建设 2026/4/12 19:26:48

华为OD机试真题 - 高效货运 (C++ Python JAVA JS GO)

高效货运 2025华为OD机试真题 - 华为OD上机考试真题 100分题型 华为OD机试真题目录点击查看: 华为OD机试真题题库目录|机考题库 + 算法考点详解 题目描述 老李是货运公司承运人,老李的货车额定载货重量为 wt。 现有两种货物: 货物 A 单件重量为 wa,单件运费利润为 pa 货…

作者头像 李华
网站建设 2026/4/7 16:51:57

揭秘多态:静态与动态的编程艺术以及多态的重载

多态//多态:同一个方法不同形态体现&#xff0c; //多态分静态多态和动态的多态 //静态多态:函数重载和符号重载 //动态多态&#xff1a;抽象和虚方法//函数重载在同一个范围内&#xff0c;函数名一样&#xff0c;参数的类型不一样、参数的个数不一样&#xff0c;这样函数就是重…

作者头像 李华