在做数据表格渲染的时候,经常遇到的需求的就是将导出excel,下面是使用vue进行项目数据进行导出的方法。

一、安装依赖

npm i -S file-saver
npm i -S xlsx

二、在src目录下新建utilsl文件夹,新建json2excel.js,并引入依赖

import { saveAs } from 'file-saver'
import XLSX from 'xlsx/dist/xlsx.full.min' // 将json数据处理为xlsx需要的格式
function datenum(v, date1904) {
if (date1904) v +=
let epoch = Date.parse(v)
return (epoch - new Date(Date.UTC(, , ))) / ( * * * )
} function data2ws(data) {
const ws = {}
const range = {s: {c: , r: }, e: {c: , r: }}
for (let R = ; R != data.length; ++R) {
for (let C = ; C != data[R].length; ++C) {
if (range.s.r > R) range.s.r = R
if (range.s.c > C) range.s.c = C
if (range.e.r < R) range.e.r = R
if (range.e.c < C) range.e.c = C
const cell = { v: data[R][C] }
if (cell.v == null) continue
const cell_ref = XLSX.utils.encode_cell({c: C, r: R}) if (typeof cell.v === 'number') cell.t = 'n'
else if (typeof cell.v === 'boolean') cell.t = 'b'
else if (cell.v instanceof Date) {
cell.t = 'n'
cell.z = XLSX.SSF._table[]
cell.v = datenum(cell.v)
}
else cell.t = 's' ws[cell_ref] = cell
}
}
if (range.s.c < ) ws['!ref'] = XLSX.utils.encode_range(range)
return ws
}
// 导出Excel
function Workbook() {
if (!(this instanceof Workbook)) return new Workbook()
this.SheetNames = []
this.Sheets = {}
} function s2ab(s) {
const buf = new ArrayBuffer(s.length)
const view = new Uint8Array(buf)
for (let i = ; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF
return buf
} /*
* th => 表头
* data => 数据
* fileName => 文件名
* fileType => 文件类型
* sheetName => sheet页名
*/
export default function toExcel ({th, data, fileName, fileType, sheetName}) {
data.unshift(th)
const wb = new Workbook(), ws = data2ws(data)
sheetName = sheetName || 'sheet1'
wb.SheetNames.push(sheetName)
wb.Sheets[sheetName] = ws
fileType = fileType || 'xlsx'
var wbout = XLSX.write(wb, {bookType: fileType, bookSST: false, type: 'binary'})
fileName = fileName || '列表'
saveAs(new Blob([s2ab(wbout)], {type: "application/octet-stream"}), `${fileName}.${fileType}`)
}

具体使用:

第一种方式:组件引入

<template>
<div style="padding:40px;">
<el-button type="primary" size="small" @click="downExcel">导出EXCEL</el-button>
</div>
</template> <script>
import toExcel from '@/utils/json2excel'
export default {
name: "landing-page",
data() {
return {
excelData: [
{name: '张三',birthday: new Date('1990-01-01'),sex: '男',age: 28},
{name: '李四',birthday: new Date('1991-01-01'),sex: '女',age: 27}
]
};
},
mounted() {},
methods: {
downExcel() {
const th = ['姓名', '生日', '性别', '年龄']
const filterVal = ['name', 'birthday', 'sex', 'age']
const data = this.excelData.map(v => filterVal.map(k => v[k]))
const [fileName, fileType, sheetName] = ['测试下载', 'xlsx', '测试页']
toExcel({th, data, fileName, fileType, sheetName})
}
}
};
</script>

第二种:全局挂载使用

1、在main.js中全局挂载toExcel方法

import toExcel from '@/excel/json2excel'
Vue.prototype.$toExcel = toExcel

2、在组件中调用toExcel方法导出excel

<template>
<div style="padding:40px;">
<el-button type="primary" size="small" @click="downExcel">导出EXCEL</el-button>
</div>
</template> <script>
import toExcel from '@/utils/json2excel'
export default {
name: "landing-page",
data() {
return {
excelData: [
{name: '张三',birthday: new Date('1990-01-01'),sex: '男',age: 28},
{name: '李四',birthday: new Date('1991-01-01'),sex: '女',age: 27}
]
};
},
mounted() {},
methods: {
downExcel() {
const th = ['姓名', '生日', '性别', '年龄']
const filterVal = ['name', 'birthday', 'sex', 'age']
const data = this.excelData.map(v => filterVal.map(k => v[k]))
const [fileName, fileType, sheetName] = ['测试下载', 'xlsx', '测试页']
this.$toExcel({th, data, fileName, fileType, sheetName})
}
}
};
</script>

技术支持:昆明猫咪科技

vue---将json导出Excel的方法的更多相关文章

  1. Vue中导出Excel表格方法

    本文记录一下在Vue中实现导出Excel表格的做法.参考度娘上各篇博客,最后实现功能 Excel表格,我的后端返回的是数据流,然后文件名是放进了content-disposition中,前端进行获取. ...

  2. asp.net中导出Excel的方法

    一.asp.net中导出Excel的方法: 本文转载 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出 ...

  3. ASP.NET导出excel表方法汇总

    asp.net里导出excel表方法汇总  1.由dataset生成 public void CreateExcel(DataSet ds,string typeid,string FileName) ...

  4. 懒人小工具:自动生成Model,Insert,Select,Delete以及导出Excel的方法

    在开发的过程中,我们为了节约时间,往往会将大量重复机械的代码封装,考虑代码的复用性,这样我们可以节约很多时间来做别的事情.最近跳槽到一节webform开发的公司,主要是开发自己公司用的ERP.开始因为 ...

  5. 懒人小工具:T4自动生成Model,Insert,Select,Delete以及导出Excel的方法

    之前写了篇文章,懒人小工具:[自动生成Model,Insert,Select,Delete以及导出Excel的方法](http://www.jianshu.com/p/d5b11589174a),但是 ...

  6. 懒人小工具:T4生成实体类Model,Insert,Select,Delete以及导出Excel的方法

    由于最近公司在用webform开发ERP,用到大量重复机械的代码,之前写了篇文章,懒人小工具:自动生成Model,Insert,Select,Delete以及导出Excel的方法,但是有人觉得这种方法 ...

  7. 懒人小工具1:winform自动生成Model,Insert,Select,Delete以及导出Excel的方法

       懒人小工具2:T4自动生成Model,Insert,Select,Delete以及导出Excel的方法    github地址:https://github.com/Jimmey-Jiang/J ...

  8. java根据xml配置文件导出excel通用方法

    java web项目中时常会用到导出功能,而导出excel几乎是每个项目必备的功能之一.针对形形色色的导出方法及个人平时的工作经验,特将导出excel方法整理成通用的方法,根据xml配置来实现特定的导 ...

  9. vue 纯前端导出 excel 表格

    在开发后台管理系统的时候,很多地方都要用到导出excel 表格,比如将table中的数据导出到本地,那么实现这种需求往往有两种方案: 一.后端开发一个下载链接,前端将这个链接放到 a 标签的 href ...

随机推荐

  1. unittest管理用例生成测试报告

    #登录方法的封装 from appium import webdriver from time import sleep from python_selenium.Slide import swipe ...

  2. python统计两个字符串从首字符开始最大连续相同的字符数

    在python中统计两个字符串从首字符开始最大连续相同的字符数,函数如下: def get_num(s1, s2): num = 0 len_s1 = len(s1) list_s1 = [] for ...

  3. Odoo仪表盘详解

    转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/10826324.html 一:仪表盘与看板的区别 kanban:kanban是一种视图类型,卡片式视图.可以为 ...

  4. 详解Apache服务与高级配置,(主配置文件每行都有描述)

    HTTP服务---> http://httpd.apache.org/(官方网站) httpd  service :纯粹的web服务器,同时开源(不是GPL). 特性:1.在进程特性上通常是事先 ...

  5. JVM垃圾收集算法之标记算法

    前言 总所周知,jvm的垃圾收集算法一般包括标记.清除.整理三个阶段,最近在看了有关于垃圾收集的标记算法,记录一下自己的理解. 垃圾收集中标记算法有两种:一种是引用计数法,一种是根搜索算法. 引用记数 ...

  6. 小型SSM项目出现Failed to load ApplicationContext错误的解决方法(个人向)

    使用单元测试的时候,出现了Failed to load ApplicationContext错误,在添加了一个新的Mapper.xml文件才出现的,在保证其他配置文件没有出错的情况下,检查mapper ...

  7. Alpha项目测试--个人第五次博客

    第五次个人博客--测试 这个作业属于哪个课程 系统分析与设计 这个作业的要求在哪里 Alpha项目测试 团队名称 西柚排课王 这个作业的目标 测试别人的项目,从客观的角度体验项目 一.测试项目一 团队 ...

  8. PHP写一个最简单的MVC框架

    照网上看的.Framework.class.php文件是灵魂. <?php class Framework { public static function run() { //echo &qu ...

  9. linux系统时区问题

    1. centos 7 转载自:https://www.cnblogs.com/zhangeamon/p/5500744.html 查看时区: timedatectl $timedatectl sta ...

  10. NetEQ主要文件简介

    accelerate.h,accelerate.cc 加速操作,对语音信号处理以实现快速播放. Accelerate类继承自父类TimeStretch,大多数功能由TimeStretch实现. Ret ...