【在前端不用接口直接导出.xlsx文件】

一:

注意:ref="table"

javascript 复制代码
          <el-button type="primary" icon="el-icon-download" @click="exportExcel">导出Excel</el-button>

         <el-table :data="codeData" border ref="table">
            <el-table-column label="数据实体" prop="dataName" align="center"/>
            <el-table-column label="更新时间" prop="updateTime" align="center"/>
          </el-table>

二:引入方法:

javascript 复制代码
import { deleteCol } from '@/utils/excel'

三:methods:

javascript 复制代码
    exportExcel() {
      const workbook = this.$xlsx.utils.table_to_book(this.$refs.table.$el, { raw: true })
      deleteCol(workbook.Sheets[workbook.SheetNames[0]], 8)
      return this.$xlsx.writeFile(workbook, 'download.xlsx')
    },

四:引入的文件内容:

/utils/excel

javascript 复制代码
import * as xlsx from 'xlsx'

function encodeCell(r, c) {
  return xlsx.utils.encode_cell({ r, c })
}

export function deleteRow(ws, index) {
  const range = xlsx.utils.decode_range(ws['!ref'])
  for (let row = index; row < range.e.r; row++) {
    for (let col = range.s.c; col <= range.e.c; col++) {
      ws[encodeCell(row, col)] = ws[encodeCell(row + 1, col)]
    }
  }
  range.e.r--
  ws['!ref'] = xlsx.utils.encode_range(range.s, range.e)
}

export function deleteCol(ws, index) {
  const range = xlsx.utils.decode_range(ws['!ref'])
  for (let col = index; col < range.e.c; col++) {
    for (let row = range.s.r; row <= range.e.r; row++) {
      ws[encodeCell(row, col)] = ws[encodeCell(row, col + 1)]
    }
  }
  range.e.c--
  ws['!ref'] = xlsx.utils.encode_range(range.s, range.e)
}

export function exportExcelFile(array, sheetName = '表1', fileName = 'example.xlsx') {
  let jsonWorkSheet = xlsx.utils.json_to_sheet(array)
  let workBook = xlsx.utils.book_new()
  workBook = {
    SheetNames: [sheetName],
    Sheets: {
      [sheetName]: jsonWorkSheet,
    },
  }
  return xlsx.writeFile(workBook, fileName)
}
相关推荐
Code_Dragon1 分钟前
最近遇到的bug
linux·前端
言兴1 分钟前
从输入 URL 到页面显示:深入理解浏览器缓存机制
前端·javascript·面试
讨厌吃蛋黄酥1 分钟前
前端跨域难题终结者:从JSONP到CORS,一文搞定所有跨域问题!
前端·javascript·后端
阿星做前端2 分钟前
coze源码解读:项目启动
前端·javascript
言兴3 分钟前
面试题之解析“类组件”与“组件”的本质
前端·javascript·面试
Jessica07063 分钟前
【Vue3+Element Plus】修改el-table树形结构的默认箭头样式
前端
excel4 分钟前
前端布局避坑指南:Grid、Flex 与传统 CSS2 布局的优缺点全解析
前端
潘小安6 分钟前
『译』2025 年 MCP 工具终极指南:6 款颠覆性 AI 开发工具,让你的生产力提升 10 倍
前端·ai编程·mcp
小林的技术分享6 分钟前
关于排查 Flutter 3.27.0 版本Android端无法禁用Impeller引擎的过程记录
前端·flutter
南篱7 分钟前
React 受控 vs 非受控组件:核心概念解析
前端·面试