VUE2 + ElementUI 将Table数据导出为Excel文件——vue-json-excel

背景

使用vue-json-excel在前端实现表格数据的导出

安装

npm install vue-json-excel --save

全局注册

频繁使用的情境下

javascript 复制代码
import Vue from 'vue';
import JsonExcel from 'vue-json-excel';

Vue.component('downloadExcel', JsonExcel);

单文件使用

可直接复制

xml 复制代码
<!--封装好的下载组件-->
<template>
    <vue-json-excel ref="excelDownloader" :data="tableData" :fields="downloadFields" :name="exportName"
        :before-generate="beforeGenerate" :before-finish="beforeFinish">
        <el-button icon="el-icon-download" type="success">{{ downloadText }}
        </el-button>
    </vue-json-excel>
</template>

<script>
// 1. 引入插件
import VueJsonExcel from 'vue-json-excel'

export default {
    name: "Download",
    components: {
        VueJsonExcel
    },
    props: {
        downloadText: {
            type: String,
            default: "导出当前数据"
        },
        tableData: {
            type: Array,
            default: () => []
        },
        columns: {
            type: Array,
            default: () => []
        },
        exportName:{
            type: String,
            default: "下载文件"
        }
    },
    data() {
        return {
            downloadFields: {},
        }
    },
    mounted() {
    // 将表格列转换成json的格式, 例如 :{ 姓名: 'name', 年龄:'age'}
        this.downloadFields = this.columns.reduce((prev, cur) => {
            prev[cur.label] = cur.prop
            return prev
        }, {})

    },
    methods: {
    // 导出前准备工作
        beforeGenerate() {
            if (this.tableData.length === 0) {
                this.$message.error('表格数据为空')
                return false
            }
            return true
        },
    // 导出完成后的前置工作
        beforeFinish() {
            this.$message.success("导出成功");
            return true
        },

    }
}
</script>

主要配置项

属性名 类型 描述 默认值 是否必填
data Array 要导出的JSON数据源 ---
fields Object 定义导出的列。对象的键是Excel表头,值是对应的JSON数据字段名。如果不提供,将导出数据对象的所有字段 ---
name String 导出的文件名 data.xls
type String 导出的文件类型,可选 xlscsv xls
header String/Array 在表格数据上方添加额外的标题行 ---
footer String/Array 在表格数据下方添加额外的脚注行 ---
worksheet String Excel工作表的名称 Sheet1
default-value String 当数据中的某个字段为空时,使用的默认值 ''(空字符串)
fetch Function 高级用法:一个异步函数,点击按钮时触发,用于动态获取数据。注意 :如果同时设置了 data 属性,fetch 不会执行 ---
before-generate Function 开始生成文件前的回调函数,常用于显示加载状态 ---
before-finish Function 文件生成完成、即将弹出下载前的回调函数,常用于隐藏加载状态 ---
相关推荐
一点一木1 天前
深度体验TRAE SOLO移动端7天:作为独立开发者,我把工作流揣进了兜里
前端·人工智能·trae
天外飞雨道沧桑1 天前
TypeScript 中 omit 和 record 用法
前端·javascript·typescript
Lee川1 天前
mini-cursor 揭秘:从 Tool 定义到 Agent 循环的完整实现
前端·人工智能·后端
canonical_entropy1 天前
从 Spec-Driven Development 到 Attractor-Guided Engineering
前端·aigc·ai编程
研☆香1 天前
聊聊前端页面的三种长度单位
前端
给钱,谢谢!1 天前
React + PixiJS 实现果园成长页:从状态机到浇水动画
前端·react.js·前端框架
暗冰ཏོ1 天前
VUE面试题大全
前端·javascript·vue.js·面试
次元工程师!1 天前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
Bug-制造者1 天前
现代Web应用全栈开发:从架构设计到部署落地实战
前端
青春喂了后端1 天前
IntelliGit 前端状态层重构:把一个全局 Store 拆成清晰的状态边界
前端·重构·状态模式