龙空技术网

vue将数据导出为excel文件就是如此简单

漏电的电鳗 801

前言:

当前姐妹们对“从java导出excel”大约比较关怀,小伙伴们都需要剖析一些“从java导出excel”的相关资讯。那么小编也在网上收集了一些有关“从java导出excel””的相关资讯,希望你们能喜欢,同学们一起来学习一下吧!

前言:

在以前需要将数据导出为excel文件时,往往需要后端提供支持,后端导出后以文件流的形式进行下载。但也带了一些问题,如:

1、 代码量复杂,一般前端难以完成。

2、 实现数据导出往往会大量消耗服务器的性能,对于网站而言是非常不利的。

随着前端的不断发展,现在只需要将数据传到前端,让前端实现数据导出为excel。

JavaScript组件库:js-xlsx。

安装:

将命令提示符切换到项目根目录执行安装代码(npm install js-xlsx --save),待进度条完成后便可实现安装。

导出原理:

将json数据的key替换为需要定义的名称,然后将json数据进行传递即可完成输出。

源码:

<template>

<div>

<el-button

slot="reference"

type="danger"

size="small"

icon="el-icon-finished"

:disabled="selection_button_state"

@click="dialogVisible = true"

>{{ selection_button_title }}</el-button

>

<el-dialog title="文件名和sheet不能为空" :visible.sync="dialogVisible">

<div>

<el-form ref="form" :model="form" label-width="100px">

<el-form-item label="导出文件名">

<el-input v-model="form.file_name"></el-input>

</el-form-item>

<el-form-item label="sheet名称">

<el-input v-model="form.sheet_name"></el-input>

</el-form-item>

</el-form>

</div>

<span slot="footer" class="dialog-footer">

<el-button size="small" type="warning" @click="dialogVisible = false"

>取 消</el-button

>

<el-button

size="small"

type="danger"

:disabled="form.sheet_name == ''"

@click="outExcel()"

>确认导出</el-button

>

</span>

</el-dialog>

</div>

</template>

<script>

import XLSX from "xlsx";

export default {

props: ["selection_button_state", "selection_button_title", "selection_data"],

data() {

return {

dialogVisible: false,

form: {

file_name: "",

sheet_name: "",

},

};

},

methods: {

outExcel() {

let tableData = [

[

"昵称",

"用户名",

"用户邮箱",

"用户电话",

"性别",

"用户年龄",

"用户类别",

],

]; // 自定义表格表头

this.selection_data.forEach((item) => {

let rowData = [];

rowData = [

item.user_pet_name,

item.user_name,

item.user_email,

item.user_phone,

item.user_sex,

item.user_age,

item.user_label,

]; //每行对应的数据

tableData.push(rowData);

});

let ws = XLSX.utils.aoa_to_sheet(tableData);

let wb = XLSX.utils.book_new();

XLSX.utils.book_append_sheet(wb, ws, this.form.sheet_name); // 工作簿名称

XLSX.writeFile(wb, this.form.file_name + ".xlsx"); // 保存的文件名

this.$message.success("已导出选中数据成功,请您查看下载的excel");

},

},

};

</script>

结语:

你如果喜欢可以前往euiadmin.com体验数据的导入和导出,也可以下载整个euiadmin后台管理源码进行学习参观。

喜欢可以"关注、点赞、评论"三联一波。

标签: #从java导出excel #java直接导出excel