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

13 阅读2分钟

背景

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

安装

npm install vue-json-excel --save

全局注册

频繁使用的情境下

import Vue from 'vue';
import JsonExcel from 'vue-json-excel';

Vue.component('downloadExcel', JsonExcel);

单文件使用

可直接复制

<!--封装好的下载组件-->
<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>

主要配置项

属性名类型描述默认值是否必填
dataArray要导出的JSON数据源
fieldsObject定义导出的列。对象的键是Excel表头,值是对应的JSON数据字段名。如果不提供,将导出数据对象的所有字段
nameString导出的文件名data.xls
typeString导出的文件类型,可选 xls 或 csvxls
headerString/Array在表格数据上方添加额外的标题行
footerString/Array在表格数据下方添加额外的脚注行
worksheetStringExcel工作表的名称Sheet1
default-valueString当数据中的某个字段为空时,使用的默认值''(空字符串)
fetchFunction高级用法:一个异步函数,点击按钮时触发,用于动态获取数据。注意:如果同时设置了 data 属性,fetch 不会执行
before-generateFunction开始生成文件前的回调函数,常用于显示加载状态
before-finishFunction文件生成完成、即将弹出下载前的回调函数,常用于隐藏加载状态