专栏首页娱乐心理测试在vue.js中如何导出Excel表格

在vue.js中如何导出Excel表格

有一个项目需求,要求在前端项目中导出Excel表格,经过查找代码,Vue.js确实可以实现,具体实现步骤为:

1. 安装依赖

//npm 
npm install -S file-saver xlsx
npm install -D script-loader

或者

//yarn
yarn add file-saver
yarn add xlsx
yarn add script-loader --dev

2.导入两个JS

下载Blob.js和Export2Excel.js,在src目录下新建Excel文件夹,里面放入Blob.js和Export2Excel.js两个JS文件

image

**3.在main.js引入这两个JS文件 **

import Blob from './excel/Blob'
import Export2Excel from './excel/Export2Excel.js'

4.在组件中使用

//导出的方法
exportExcel() {
      require.ensure([], () => {
        const { export_json_to_excel } = require('../excel/Export2Excel');
        const tHeader = ['序号', '昵称', '姓名'];
        // 上面设置Excel的表格第一行的标题
        const filterVal = ['index', 'nickName', 'name'];
        // 上面的index、nickName、name是tableData里对象的属性
        const list = this.tableData;  //把data里的tableData存到list
        const data = this.formatJson(filterVal, list);
        export_json_to_excel(tHeader, data, '列表excel');
      })
    },

    formatJson(filterVal, jsonData) {
      return jsonData.map(v => filterVal.map(j => v[j]))
    }

tHeader是表头,filterVal 中的数据是表格的字段,tableData中存放表格里的数据,类型为数组,里面存放对象,表格的每一行为一个对象。

tableData 中的值为:

data () {
    return {
      tableData: [
        {'index':'0',"nickName": "沙滩搁浅我们的旧时光", "name": "小明"},
        {'index':'1',"nickName": "女人天生高贵", "name": "小红"},
        {'index':'2',"nickName": "海是彩色的灰尘", "name": "小兰"}
      ]
    }
  }

最后实现的效果图:

image

如果运行时,报如下所示的错误:

image

这是因为Export2Excel.js的设置需要改下:

image

注: 把require('script-loader!vendor/Blob')改为 require('./Blob.js') demo 地址:https://github.com/dt8888/exportExcel

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 快速初始化一个mpvue 项目

    mpvue 是一个使用 Vue.js 开发小程序的前端框架。框架基于 Vue.js 核心,mpvue 修改了 Vue.js 的 runtime 和 compil...

    honey缘木鱼
  • Ios常用第三方动画框架(三)

    honey缘木鱼
  • 私有api:com.apple.springboard.lockcomplete审核被拒

    honey缘木鱼
  • TensorFlow全新的数据读取方式:Dataset API入门教程

    作者:何之源 首发于知乎专栏:AI Insight 量子位 已获授权编辑发布 转载请联系原作者 Dataset API是TensorFlow 1.3版本中引入的...

    量子位
  • 单数据库,多数据库,单实例,多实例不同情况下的数据访问效率测试

    最近公司的项目准备优化一下系统的性能,希望在数据库方面看有没有提升的空间,目前压力测试发现数据库服务器压力还不够大,Web服务器压力也不是很大的情况下,前台页面...

    用户1177503
  • OAuth2.0协议详解

    更多可以访问:https://tools.ietf.org/html/rfc6749

    开发架构二三事
  • Python: 全局变量 & 局部变量的使用

      码Python代码时,想用全局变量,报了错。所以上网查了相关文档,总结出 以下几点 :

    JNingWei
  • Spring Boot集成MyBatis实现通用Mapper

    关于MyBatis,大部分人都很熟悉。MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JD...

    aoho求索
  • 4-AVI--Fragment与ViewPager结合

    张风捷特烈
  • 【JavaScript】当我们尝试用JavaScipt测网速

    https://www.npmjs.com/package/network-speed-test

    外婆的彭湖湾

扫码关注云+社区

领取腾讯云代金券