vue将指定区域的表格数据或element-ui中el-table的数据单笔或多笔批量导出excel
公司在后台管理系统开发中用到了 vue+element-ui 组合的框架,但随着需求的越来越复杂,前端的工作难度也呈几何倍数递增,工作量随之增大。这不,在项目中增加一个将列表数据导出为excel的需求就紧跟着来了。
不光将数据导出,还得支持单笔导出或多笔批量导出。
前端:前端招谁惹谁了?
产品:入了前端门,生是前端人,死是前端鬼!
前端:

产品:

为了生活,我们已经殚精竭虑;为了工作,我们已经竭尽全力!
有需求,哭着也得实现啊。于是上网搜了一通,果然让我发现了解决之道:xlsx、file-saver和script-loader。
接下来就说说具体的实现方法:
上边提到了三个插件:xlsx、file-saver和script-loader,对,你没看错,就是三个插件,实现一个功能,需要三个插件,没办法啊。就像你的银行卡要用六位数的密码来保护两位数的余额一样,你有什么办法呢?谁让你败家呢?

一、 安装三个依赖项
npm install -S file-saver
npm install -S xlsx
npm install -D script-loader
二、在项目中新建一个文件夹(一般在src下新建,文件名自取,在这里命名为excel),在文件夹中放入Blob.js 和 export2Excel.js (这两个文件可在gitup上进行下载)
三、vue组件调用(由于项目中很多页面都会用到,所以我就封装成了公共的方法)
import html2Canvas from 'html2canvas'
import JsPDF from 'jspdf'
/*
* 导出excel
* @param { Array } params.excelHeader 导出excel的表头
* @param { Array } params.excelFilterVal 导出数据所需的字段(multipleSelection或defaultList对象的属性)
* @param { Array } params.multipleSelection 导出勾选的单笔或多笔数据
* @param { Array } params.defaultList 默认导出列表所有数据
* @param { Array } params.fileName 导出excel的文件名
*/
export function export2Excel(params){
let excelHeader = params.excelHeader || ['类型', '合同号', '账户名', '币种', '金额']
let excelFilterVal = params.excelFilterVal || ['type', 'contractCode', 'accountName', 'currency', 'amount']
require.ensure([], () => {
let { export_json_to_excel } = require('@/excel/Export2Excel');
//默认为导出全部列表,也可以单笔导出或勾选多笔批量导出
let listArr = params.multipleSelection.length > 0 ? JSON.parse(JSON.stringify(params.multipleSelection)) : JSON.parse(JSON.stringify(params.defaultList));
let formatData = formatJson(excelFilterVal, listArr);
export_json_to_excel(excelHeader, formatData, params.fileName);
})
}
function formatJson(excelFilterVal, listArr) {
return listArr.map(v => {
switch(v.type){
case '01':
v.type = '小贷';
break;
case '02':
v.type = '租赁';
break;
case '03':
v.type = '电商';
break;
}
return excelFilterVal.map(j => v[j]);
})
}
说明:
1、以上代码在文件路径上用到了“@”符号,不懂的同学可自行查阅资料;
2、以上代码用到了JSON.stringify和JSON.parse,主要是因为对象的引用的问题。我们都知道,在将一个对象赋值给另一个对象时,如果其中一个对象的某个属性值被修改了也会影响到另一个对象的某个属性值的改变,这是因为他们在内存中实际上是指向了同一个引用地址,所以我就先用JSON.stringify将目标对象(这里是一个数组,数组也是Object对象,没毛病)转变成一个字符串,让其在内存中开辟一个新的地址,这样就切断了引用对象的指针联系,然后再用JSON.parse将字符串转变为一个数组,就解决了引用对象之间互相影响的问题。导出excel方法中调用的formatJson函数中的type字段映射的文字跟页面中映射的文字稍微不同(formatJson函数修改的是listArr数组,而listArr数组是通过页面展示的默认数组defaultList或用户选择的数据数组multipleSelection赋值得来的),就会出现一个对象对另一个对象的影响,因此不得不使用了JSON.stringify和JSON.parse。
3、关于multipleSelection,这个是用了element-ui中el-table的多选功能。正是这个功能才是能实现单笔导出或多笔批量导出的关键,当选择了单笔或多笔时,multipleSelection存储的就是你选择的数据(详见element-ui的表格组件API),然后判断该数组是否为空,若为空,则默认导出列表的所有数据,若不为空,则导出选择的列表数据:
let listArr = params.multipleSelection.length > 0 ? JSON.parse(JSON.stringify(params.multipleSelection)) : JSON.parse(JSON.stringify(params.defaultList));
4、网上还有其他解决方案,详见vue2.0 + element UI 中 el-table 数据导出Excel等等,此类方案倒没有本文的解决方案那么麻烦,但有一个问题就是无法自行选择具体导出表格哪些列的数据,它是一股脑将表格的所有数据都导出了,包括对表格数据的一些按钮操作如修改按钮、删除按钮等,甚至将表格第一列的checkbox复选框也导出了,虽然插件xlsx 有一个参数display为true时可以将隐藏的行和单元格的数组不被解析(具体使用方法没有用过,不甚了解),但如果将表格的行或单元格设置为隐藏,那我们还在页面中展示数据干嘛?显然,这种解决方案虽然简单,但灵活度不够,适用于比较简单的只展示数据的表格的导出。
本文参考:
https://blog.csdn.net/xiaoshihoukediaole/article/details/81296327
https://www.jianshu.com/p/6edf74f65fc1
vue将指定区域的表格数据或element-ui中el-table的数据单笔或多笔批量导出excel的更多相关文章
- IOS开发数据存储篇—IOS中的几种数据存储方式
IOS开发数据存储篇—IOS中的几种数据存储方式 发表于2016/4/5 21:02:09 421人阅读 分类: 数据存储 在项目开发当中,我们经常会对一些数据进行本地缓存处理.离线缓存的数据一般都 ...
- IFC构件位置数据与revit模型中对应构件位置数据对比
IFC构件位置数据与revit模型中对应构件位置数据对比
- 在vue中关于element UI 中表格实现下载功能,表头添加按钮,和点击事件失效的解决办法。
因为在element 中表格是使用el-table的形式通过数据来支撑结构,所以,表格的样式没有自己写的灵活,所以有了没法添加按钮的烦恼.下面是解决的方法. 准备工作: 一.下载npm安装包两个 1. ...
- vue实现多语言国际化(vue-i18n),结合element ui、vue-router、echarts以及joint等。
老板说我们的项目要和国际接轨,于是乎,加上了多语言(vue-i18n).项目用到的UI框架是element ui ,后续echarts.joint等全都得加上多语言. 一.言归正传,i18n在vue项 ...
- vue+element ui中select组件选择失效问题原因与解决方法
codejing 2020-07-10 09:13:31 652 收藏 分类专栏: Web Vue Element UI 版权 .当表单form赋完值后,如果后续又对form中某一属性值进行操作如 ...
- 【poi】用POI新建一个xlsx文件【或者说将数据存入到xlsx中】/【将数据从xlsx中获取到项目中】
第一部分:写入xlsx中 使用POI创建一个xlsx文件: 项目结构如下: 具体使用的POI中的 XSSFWorkbook xlsx对象 Sheet 工作簿对象 Row 行对象 Cell 单元格 ...
- Element Ui中table实现表格编辑效果
主要以css实现 .tb-edit .el-input, .tb-edit .el-input-number, .tb-edit .el-select { display: none; width: ...
- element ui中循环出来的表格勾选问题
需求是这样的,一个房主屋里面有多个电表,每一个表是一个账户,一次只能给一个账户缴费,在点击go按钮进行缴费,这个时候判断是否跨表勾选,跨表格勾选则弹窗提示,反之符合需求,走缴费逻辑 上代码 <! ...
- vue学习笔记(二): 添加 element ui 插件
一.加载 ui element vue add element 加载过程及成功结果如下 > vue add element>
随机推荐
- 好奇,项目根目录下的.editorconfig文件
一..editorconfig文件是什么? 在项目里,大多时候都能看到.editorconfig文件,刚开始总是忽视掉它,认为它不太重要.但是,它的存在,必定有它的理由,于是,抽空来研究一下,它是什么 ...
- Theano.tensor.round函数学习,同时解决输出Elemwise{xxx,no_inplace}.0的问题
1. 出现Elemwise{xxx,no_inplace}.0 这是因为没有定义theano.function所致,参考下面错误示范: y = np.random.normal(size=(2,2 ...
- Python3的保留字
Python3的保留字 false none true and 表示条件的并列,并且条件全部成立 as assert break class continue def del elif else ex ...
- python把列表前几个元素提取到新列表
需要添加几个就循环几次 list = ['a','b','c','d','e'] new_list = [] for i in range(3): print(list[i]) new_list. ...
- mysql插入大数据
/*部门表*/ CREATE TABLE dept( id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT, /*id*/ deptno MEDIUMINT UNSIG ...
- gitlab 随笔
输入: $ git init $ git add . $ git commit -m 'init commit' 绿色部分为gitlab网页的项目创建后下面的ssh路径,也可以通过查看gitlab网页 ...
- 深入Java虚拟机:多态性实现机制——静态分派与动态分派
方法解析 Class文件的编译过程中不包含传统编译中的连接步骤,一切方法调用在Class文件里面存储的都只是符号引用,而不是方法在实际运行时内存布局中的入口地址.这个特性给Java带来了更强大的动态扩 ...
- 01-Linux操作系统+指令
一.Linux操作系统 操作系统定义:操作系统直接运行在计算机上的系统软件, 它是与硬件打交道和控制软件运行的计算机程序. 虚拟机:就是模拟一个真实的计算机,好比一个虚拟的电 ...
- windows安装多个python及pip版本
windows安装多个python及pip版本 1.下载所需要的python2和python3安装包 2.一路next 3.设置环境变量 4.修改python安装目录下的可执行程序名称 5.在cmd中 ...
- topological sort~~~~初学
今天讲了topological sort 问题: 判环:记录入队的点数,若<n则有环,可证: 算法:o(n):queue or stack,而不是o(n^2)枚举 #. 关系运算图(vijos ...