vue导出数据到excel

安装插件

bash 复制代码
npm install exceljs file-saver

页面代码

vue 复制代码
<template>
  <div class="test-form">
    <div @click="exportData" class="export-btn">导出为excel</div>
  </div>
</template>

<script setup>
// 导出文件
import ExcelJS from 'exceljs'
import FileSaver from 'file-saver'
import { ref } from 'vue'
// 模拟表格数据
const tableData = ref([
  { name: '张三', age: 25, city: '北京' },
  { name: '李四', age: 30, city: '上海' },
  { name: '王五', age: 35, city: '广州' },
  { name: '赵六', age: 40, city: '深圳' },
  { name: '王二', age: 45, city: '成都' },
  { name: '赵四', age: 50, city: '重庆' },
  { name: '王三', age: 55, city: '西安' },
  { name: '王五', age: 60, city: '北京' },
  { name: '赵五', age: 65, city: '天津' },
  { name: '王四', age: 70, city: '大连' },
])

function fileExcel(fileData, fileName = '汇总') {
  // 创建工作簿
  const workbook = new ExcelJS.Workbook()
  // 添加工作表,名为sheet1
  const sheet1 = workbook.addWorksheet('sheet1')
  // 导出数据列表
  const data = fileData
  // 获取表头所有键
  const headers = Object.keys(data[0])
  // 将标题写入第一行
  sheet1.addRow(headers)
  // 将数据写入工作表
  data.forEach(row => {
    const values = Object.values(row)
    sheet1.addRow(values)
  })
  // 导出表格文件
  workbook.xlsx
    .writeBuffer()
    .then(buffer => {
      let file = new Blob([buffer], { type: 'application/octet-stream' })
      FileSaver.saveAs(file, fileName + '.xlsx')
    })
    .catch(error => console.log('Error writing excel export', error))
}

// 导出数据
const exportData = () => {
  // 处理键名(表头格式)
  const processedData = tableData.value.map(item => {
    return {
      姓名: item.name,
      年龄: item.age,
      城市: item.city,
    }
  })
  fileExcel(processedData, '导出数据')
}
</script>

<style scoped lang="scss">
.test-form {
    .export-btn {
      display: inline-block;
      padding: 10px 20px;
      background-color: #007bff;
      color: #fff;
      border-radius: 5px;
      cursor: pointer;
    }
}
</style>
相关推荐
开开心心就好4 天前
解决截图被拦截黑屏问题的免费小工具
安全·智能手机·flink·kafka·pdf·音视频·1024程序员节
开开心心就好9 天前
清理重复文件释放C盘空间的工具
安全·智能手机·pdf·gitlab·音视频·intellij idea·1024程序员节
数据皮皮侠AI13 天前
中国土地利用驱动因子数据集(9种驱动因子/裁剪到省市/Tif)
大数据·人工智能·笔记·能源·1024程序员节
数据皮皮侠AI17 天前
上市公司耐心资本数据(2010-2025)
大数据·人工智能·笔记·能源·1024程序员节
开开心心就好19 天前
解决图片无页码添加功能的实用工具
javascript·python·安全·智能手机·pdf·音视频·1024程序员节
学传打活19 天前
【边打字.边学昆仑正义文化】_25_宇宙动植物的由来(1)
微信公众平台·1024程序员节·汉字·昆仑正义文化
开开心心就好24 天前
用户推荐的文件解锁与强制操作工具
安全·智能手机·pdf·scala·音视频·symfony·1024程序员节
liguojun20251 个月前
软硬一体智慧场馆系统推荐——助力场馆数字化高效升级
java·大数据·人工智能·物联网·1024程序员节
开开心心就好1 个月前
吾爱大佬原创的文件时间修改工具
安全·智能手机·pdf·电脑·智能音箱·智能手表·1024程序员节
开开心心就好1 个月前
近200个工具的电脑故障修复合集
安全·智能手机·pdf·电脑·consul·memcache·1024程序员节