首页 / VUE / Vue实现导出excel表格功能
Vue实现导出excel表格功能
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Vue实现导出excel表格功能,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3985字,纯文字阅读大概需要6分钟。
内容图文
这篇文章主要介绍了Vue实现导出excel表格的功能,在文章末尾给大家提到了vue中excel表格的导入和导出代码,需要的朋友可以参考下引言:
最近使用vue在做一个后台系统,技术栈 vue + iView ,在页面中生成表格后, iView可以实现表格的导出,不过只能导出csv格式的,并不适合项目需求。
如果想要导出Excel
在src目录下创建一个文件(vendor)进入 Blob.js 和 Export2Excel.js
npm install -S file-saver 用来生成文件的web应用程序
npm install -S xlsx 电子表格格式的解析器
npm install -D script-loader 将js挂在在全局下
表结构
渲染页面中的表结构是由 columns 列 和 tableData 行,来渲染的 columns 为表头数据 tableData 为表实体内容
tableData 就不写了,具体数据结构查看iViewAPI
在build 目录下 webpack.base.conf.js 配置 我们要加载时的路径
在当前页面中引入依赖
当我们要导出表格执行 @click 事件调用 handleDownload 函数
handleDownload() { this.downloadLoading = true require.ensure([], () => { const {export_json_to_excel} = require('src/vendor/Export2Excel') const tHeader = Util.cutValue(this.columns1, 'title') const filterVal = Util.cutValue(this.columns1, 'key') const list = this.tableData1 const data = this.formatJson(filterVal, list) export_json_to_excel(tHeader, data, '列表excel') this.downloadLoading = false }) }, formatJson(filterVal, jsonData) { return jsonData.map(v => filterVal.map(j => v[j])) }
Util.cutValue 是公共方法,目的是为了将,tHeader 和filterVal 的值转成数组从而生成表格
### Util module // 截取value值 utils.cutValue = function (target, name) { let arr = [] for (let i = 0; i < target.length; i++) { arr.push(target[i][name]) } return arr }
Export2Excel.js/Blob.js 的代码
下面再看下vue中excel表格的导入和导出
注意:vue中要实现表格的导入与导出,首先要install两个依赖,
npm install -S file-saver xlsx
和 npm install -D script-loader
。其次,在项目src目录下新建一个文件夹vendor(名字随意),在此文件夹下放置两个文件Blob.js和Export2Excal.js(下载地址:http://files.cnblogs.com/files/wangyunhui/vendor.rar)。之后就可以愉快的导入导出了微笑。
1、导入
2.导出
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
详解Vue基于 Nuxt.js 实现服务端渲染
express默认日志组件morgan的方法
React Native悬浮按钮组件的示例代码
以上就是Vue实现导出excel表格功能的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的Vue实现导出excel表格功能全部内容,希望文章能够帮你解决Vue实现导出excel表格功能所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。