vue中导出Excel表格
项目中我们可能会碰到导出Excel文件的需求,一般后台管理系统中居多,将table中展示的数据导出保存到本地。当然我们也可以通过一些处理来修改要导出的数据格式,具体需求具体对待。
1、首先我们需要安装3个依赖,file-saver、xlsx和script-loader。
使用npm安装:
npm install file-saver xlsx -S
npm install script-loader -D
使用yarn安装:
yarn add file-saver xlsx -S
yarn add script-loader -D
2、在/src目录下新建一个vendor(名字也可自取)文件夹,存入Blob.js和Export2Excel.js文件。
这个两个文件你可以直接戳这里 CSDN下载
有积分就1积分支持一下,没有也可以去我的 github下载
当然也可以自行下载,或许会有版本的问题吧。
3、在/build/webpack.base.conf.js中新增一行代码(vendor的名字必须和第二步新建的文件夹名字相同)。
resolve: {
  extensions: ['.js', '.vue', '.json'],
  alias: {
    'vue$': 'vue/dist/vue.esm.js',
    '@': resolve('src'),
    'vendor': path.resolve(__dirname, '../src/vendor') // 新增这一行
  }
}
4、在vue项目中的使用。
/**
 * excel导出
 */
exportTable () {
  // this.DefaultData.exportExcelMax限制一下导出的总条数
  if (this.totals <= this.DefaultData.exportExcelMax) {
    this.$confirm('确定要导出当前<strong>' + this.totals + '</strong>条数据?', '提示', {
      dangerouslyUseHTMLString: true,
      confirmButtonText: '确定',
      cancelButtonText: '取消'
    }).then(() => {
      this.getExpportData()
    }).catch(() => {
    })
  } else {
    this.$confirm('当前要导出的<strong>' + this.totals + '</strong>条数据,数据量过大,不能一次导出!<br/>建议分时间段导出所需数据。', '提示', {
      dangerouslyUseHTMLString: true,
      showCancelButton: false
    }).then(() => {
    }).catch(() => {
    })
  }
},
/**
 * 对导出数据格式处理
 */
formatJson (filterVal, jsonData) {
  return jsonData.map(v => filterVal.map(j => v[j]))
},
/**
 * 导出的列表数据
 */
getExpportData: function () {
  const loading = this.$loading({
    lock: true,
    text: '正在导出,请稍等......',
    spinner: 'el-icon-loading',
    background: 'rgba(0, 0, 0, 0.7)'
  })
  const data = {
    phoneNo: this.formInline.phoneNo,
    userName: this.formInline.userName,
    amount: this.formInline.amount,
    fee: this.formInline.fee,
    currentPage: this.currentPage,
    pageSize: this.DefaultData.exportExcelMax
  }
  // 这里封装了axios,根据自身情况修改即可
  this.http(
    this.ApiSetting.orderExport,
    data
  ).then((res) => {
    // handleDataList这里可以对导出的数据根据需求做下处理
    const handleDataList = res.data.list
    for (let i in res.data.list) {
      handleDataList[i].amount = res.data.list[i].amount * 100
      handleDataList[i].fee = res.data.list[i].fee + '%'
    }
    if (res.data.list.length > 0) {
      require.ensure([], () => {
        /* eslint-disable */
        // 这里的径路要修改正确
        const { export_json_to_excel } = require('../../vendor/Export2Excel')
        /* eslint-enable  */
        // 导出的表头
        const tHeader = ['手机号码', '用户姓名', '交易金额', '手续费']
        // 导出表头要对应的数据
        const filterVal = ['phoneNo', 'userName', 'amount', 'fee']
        // 如果对导出的数据没有可处理的需求,把下面的handleDataList换成res.data.list即可,删掉上面相应的代码
        const data = this.formatJson(filterVal, handleDataList)
        // this.DefaultData.formatLongDate.getNow()自己写的一个获取当前时间,方便查找导出后的文件。根据需求自行可处理。
        export_json_to_excel(tHeader, data, '订单查询列表-' + this.DefaultData.formatLongDate.getNow())
        this.$message({
          message: '导出成功',
          duration: 2000,
          type: 'success'
        })
      })
    } else {
      this.$message({
        message: '数据出錯,请联系管理员',
        duration: 2000,
        type: 'warning'
      })
    }
    loading.close()
  }, error => {
    console.log(error)
    loading.close()
  })
}
在需要导出功能的页面加入上面三个方法,修改好需要注意的事项,导出Excel表格就ok了。
来源:https://segmentfault.com/a/1190000016457561
vue中导出Excel表格的更多相关文章
- 在vue中导出excel表格
		
初学者学习vue开发,想把前端项目中导出Excel表格,查了众多帖子,踩了很多坑,拿出来与大家分享一下经验. 安装依赖 //npm npm install file-saver -S npm inst ...
 - Vue中导出Excel表格方法
		
本文记录一下在Vue中实现导出Excel表格的做法.参考度娘上各篇博客,最后实现功能 Excel表格,我的后端返回的是数据流,然后文件名是放进了content-disposition中,前端进行获取. ...
 - spring mvc项目中导出excel表格简单实现
		
查阅了一些资料,才整理出spring mvc 项目导出excel表格的实现,其实很是简单,小计一下,方便以后查阅,也希望帮助有需要的朋友. 1.导入所需要依赖(Jar包).我使用的是maven,所以坐 ...
 - vue  导出excel表格
		
对于涉及到数据比较多的管理后台导出excel 表格这个需求就非常的常见了 所以? vue 怎么到处excel表格的? 有两种办法 1:请求接口后台直接给你的是excel文件,你需要做的就是怎么接收ex ...
 - vue 纯前端导出 excel 表格
		
在开发后台管理系统的时候,很多地方都要用到导出excel 表格,比如将table中的数据导出到本地,那么实现这种需求往往有两种方案: 一.后端开发一个下载链接,前端将这个链接放到 a 标签的 href ...
 - java中使用jxl导出Excel表格详细通用步骤
		
该方法一般接收两个参数,response和要导出的表格内容的list. 一般我们将数据库的数据查询出来在页面进行展示,根据用户需求,可能需要对页面数据进行导出. 此时只要将展示之前查询所得的数据放入s ...
 - js导出excel表格中较长数字串会变成科学计数法问题
		
在做项目中,遇到导出excel表格时,银行账户号数字过长,导出的数字串变为计数法形式,如下图: 网上搜到解决方法,粘贴到这以供学习.不断更新. 原博地址:http://www.cnblogs.com/ ...
 - Vue项目中将table组件导出Excel表格以及打印页面内容
		
体验更优排版请移步原文:http://blog.kwin.wang/programming/vue-table-export-excel-and-print.html 页面中显示的table表格,经常 ...
 - NPOI_winfrom导出Excel表格(二)(直接打开Excel软件,将数据填充在当前的sheet中)
		
//// 存储路径弹框选择 SaveFileDialog saveDialog = new SaveFileDialog(); saveDialog.DefaultExt = "xls&qu ...
 
随机推荐
- yum update 出错解决办法
			
卸载掉yum和python 于是我卸载了python和yum,觉得自己重新安装python和yum. 步骤1:卸载python rpm -qa|grep python|xargs rpm -e --a ...
 - UVa10539
			
http://vjudge.net/problem/UVA-10539 先打出来sqrt(n)以内的素数表,然后对于每个素数x,他对答案的贡献就是最大的p使x^p<=n,即log(x,n).注意 ...
 - 济南学习 Day 5 T3 pm
			
科普一下: φ函数的值 通式:φ(x)=x(1-1/p1)(1-1/p2)(1-1/p3)(1-1/p4)…..(1-1/pn),其中p1, p2……pn为x的所有质因数,x是不为0的整数.φ(1)= ...
 - 星球大战 BZOJ 1015
			
星球大战 [问题描述] 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球.这些星球通过 ...
 - Linux shell中的竖线(|)——管道符号
			
管道符号,是unix一个很强大的功能,符号为一条竖线:"|". 用法: command 1 | command 2 他的功能是把第一个命令command 1执行的结果作为comma ...
 - electron 编译成exe
			
前提:现在有一个electron项目,等待打包成exe. 一,运行”electron .“,看运行是否正常.不正常则继续调试,正常可进入到第二步. 二,运行“electron-packager . m ...
 - 数字IC设计入门必备——VIM自定义模板调用与VCS基本仿真操作示例
			
一.前言 毕业论文答辩结束,闲下来写篇文章.芯片研发人员都在Linux系统下借助各种EDA工具和代码语言完成工作,因此提高代码开发效率,熟练运用开发工具是十分必要的.本文讲述VIM编辑神器的veril ...
 - codevs——1294 全排列
			
1294 全排列 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Description 给出一个n, 请输出n的所有全 ...
 - Filter和Interceptor的终归作用还是从入口修改或验证请求进来的数据
			
Filter是Java EE标准.Inteceptor是Spring 标准. Filter在servlet前面,Interveptor在servlet之后 Filter和Inteceptor都可以改变 ...
 - 【PostgreSQL】安装使用步骤
			
1.下载地址 https://www.postgresql.org/download/windows/ 下载按照较新版本,和平台相一致就好 2.安装 选择安装地址 数据存放地址 密码设置 端口使用默认 ...