JS实现把表格数据导出,并生成为excel下载到本地

这篇具有很好参考价值的文章主要介绍了JS实现把表格数据导出,并生成为excel下载到本地。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

最近开发页面用到了导出功能,之前也没有做导出为excel功能的经验,经过各方面查询尝试之后,终于成功实现,所以来总结一下

  1. 首先,你需要下载xlsx.js插件,并在HTML头部文件中需要引入,我是直接用命令行下载的:npm install xlsx --save

JS实现把表格数据导出,并生成为excel下载到本地
  1. 前端写一个按钮绑定函数:

<button @click="generateReport(0)">导出</button>
  1. js部分实现函数,因为我的数据是通过ajax从后端获取的,没有后端数据就自己编造一个,代替我代码中的this.ExcelData,或者不需要this.ExcelData,直接把return里面的内容改成你需要的,比如:你想要的表格列名1:你想要的数据1,

你想要的表格列名2:你想要的数据2 这样

//报表导出
        generateReport:function(no){
            $.ajax({
                url: '/generateReport',
                type: 'POST',
                context: this,
                data: {
                    'FLAG':no
                }
            }).done(function (data){
                console.log('opqrst',data);
                this.ExcelData = _.cloneDeep(data);
                let arr=this.ExcelData.map(item=>{
                    return {
                        阵列名称:item.SUBARRY_NAME,
                        通讯箱名称:item.COMMUNICATION_BOX_NAME,
                        通讯箱状态:item.COMMUNICATION_BOX_STATE,
                        跟踪器名称:item.TRACKER_NAME,
                        跟踪器状态:item.TRACKER_STATE,
                        跟踪模式:item.TRACKING_MODEL,
                        目标角度:item.TARGET_ANGLE,
                        实际角度:item.MEASURED_ANGLE,
                    };
                });
                console.log('version',XLSX.version);
                let sheet=XLSX.utils.json_to_sheet(arr),
                    book=XLSX.utils.book_new();
                // sheet1表示要导出的分区名字
                XLSX.utils.book_append_sheet(book,sheet,"sheet1");
                console.log("book",book)
                // user开头加时间戳的文件名,可以修改成其它名字
                XLSX.writeFile(book,`设备列表${(new Date()).getTime()}.xls`);
            })
        },
  1. 成功后测试导出:

JS实现把表格数据导出,并生成为excel下载到本地

打开浏览器的下载内容就可以查看表格:

JS实现把表格数据导出,并生成为excel下载到本地

打开xls文件,可以看到excel文件导出下载成功了:

JS实现把表格数据导出,并生成为excel下载到本地

提示:开发过程中遇到了一个报错:

XLSX.utils.json_to_sheet is not a function ,据说可能是因为 xlsx 版本问题导致的,所以在在调用 XLSX.utils.json_to_sheet() 方法前我控制台输出了自己的xlsx的版本号

console.log(XLSX.version)

百度说 0.8.8 以下版本不支持 json_to_sheet() 方法,但是我是0.8.11,不知道为啥也不支持,所以我又把原来的插件删掉了,重新下载最新版:npm install xlsx@0.14.5 --save,就ok了文章来源地址https://www.toymoban.com/news/detail-459292.html

到了这里,关于JS实现把表格数据导出,并生成为excel下载到本地的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java 导出Excel表格生成下拉框-EasyExcel

     

    2024年02月11日
    浏览(50)
  • Springboot基于easyexcel实现一个excel文件包含多个sheet表格的数据导出

    EasyExcel 是一款基于Java的开源Excel操作工具,它提供了简单且强大的 API,使开发人员可以轻松地读写、操作和生成Excel文件。 EasyExcel 支持 Excel 文件的导入和导出,可以处理大量数据,具有高性能和低内存占用。它可以读取 Excel 文件中的数据,并将数据转换为 Java 对象,也可

    2024年02月03日
    浏览(56)
  • Springboot通过前端发起请求,拿到数据库中的数据并生成excel表格,postman请求并下载文件

    springboot版本3.2.0,数据库版本8 mybatisplus版本3.5.4.1 依赖 实体类 实体类中的枚举类型转换,因调用方法后还是不能转换类型所以暂未解决 Controller层 postman测试 Excel表格 获取数据成功

    2024年01月18日
    浏览(41)
  • 【MySQL × SpringBoot 突发奇想】全面实现流程 · 数据库导出Excel表格文件的接口

    在上一篇博客,【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口_s:103的博客-CSDN博客 我们学习了如何导入表格,现在我们反过来,看看如何导出表格~ 网络资料: View Object(视图对象)是一种在软件开发中常见的设计模式,它用于在用户界面

    2024年02月08日
    浏览(47)
  • VUE+Elment-ui怎么实现将table表格数据导出到Excel文件?

    最近开发公司后台管理系统时,*运营提出了个需求就是将某表格数据实现一键导出功能,我一实习生我会啥啊,搜吧,好在找到了,捏哈哈,接下来就是实现的流程,方便理解,我见了个简单的页面供大家参考 1.template部分 2.script部分 1.当前页面 2.点击导出按钮 3.下载完成

    2024年02月05日
    浏览(43)
  • 前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法

    一、vue实现导出excel 1、前端实现 xlsx是一个用于读取、解析和写入Excel文件的JavaScript库。它提供了一系列的API来处理Excel文件。使用该库,你可以将数据转换为Excel文件并下载到本地。这种方法适用于在前端直接生成Excel文件的场景。 更多介绍可参见官网 1、安装xlsx依赖 2、引

    2024年01月23日
    浏览(77)
  • js 实现纯前端将数据导出excel两种方式

    将table标签,包括tr、td等对json数据进行拼接,将table输出到表格上实现,这种方法的弊端在于输出的是伪excel,虽说生成xls为后缀的文件,但文件形式上还是html,代码如下 通过将json遍历进行字符串拼接,将字符串输出到csv文件,代码如下

    2024年02月15日
    浏览(28)
  • Post 和 Get 两种方式实现数据导出Excel文件并下载

    Post 和 Get 两种方式实现数据导出Excel文件并下载 前端使用Vue,后端使用Springboot。 一般而言,使用post方式是比较方便的。但有时候,需要下载的数据在后端进行查询的时候很比较复杂的查询条件,而这个查询条件是前端进行下载请求的时候传递的参数,如果参数比较复杂或参

    2024年02月11日
    浏览(46)
  • 使用EasyExcel实现Excel表格的导入导出

    Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。 easyexcel重

    2024年02月12日
    浏览(44)
  • 【vue导入导出Excel】vue简单实现导出和导入复杂表头excel表格功能【纯前端版本和配合后端版本】

    前言 这是一个常用的功能,就是导入和导出excel表格 但是时常会遇到一些复杂表头的表格导出和导入 比如我这个案例里面的三层表头的表格。 网上看了下发现了一个非常简单导出和导入方法 当然这个是纯前端的版本,会出现分页不好下载的情况。所以实际工作中,导出还是

    2024年02月11日
    浏览(60)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包