博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
利用js-xlsx库,实现前端读取Excel报表文件
阅读量:6981 次
发布时间:2019-06-27

本文共 1788 字,大约阅读时间需要 5 分钟。

 

在实际开发中,经常会遇到导入Excel文件的需求,有的产品人想法更多,想要在前端直接判断文件内容格式是否正确,必填项是否已填写

 

依据HTML5的FileReader,可以使用新的API打开本地文件(参考)

  • FileReader.readAsBinaryString(Blob|File)
  • FileReader.readAsText(Blob|File, opt_encoding)
  • FileReader.readAsDataURL(Blob|File)
  • FileReader.readAsArrayBuffer(Blob|File)

 

通过 readAsBinaryString 虽然能打开二进制文件(*.pdf、*.doc、*.xls等),但如若要直接通过JS进行判断这些二进制数据是否符合要求,是不行的

所以就需要转换,对于Excel文件的内容分析转换,已经有了比较成熟的解决方案:

其实现方式也用到了上述新特性,看看具体要怎么用

 

1. 首先定义一个文件上传项

2. 下载js-xlsx的相应的  文件后引入

3. 监听文件选择,即时打开文件获取表格内容

使用XLSX.utils.sheet_to_json方法解析表格对象返回相应的JSON数据

$('#excel-file').change(function(e) {            var files = e.target.files;            var fileReader = new FileReader();            fileReader.onload = function(ev) {                try {                    var data = ev.target.result,                        workbook = XLSX.read(data, {                            type: 'binary'                        }), // 以二进制流方式读取得到整份excel表格对象                        persons = []; // 存储获取到的数据                } catch (e) {                    console.log('文件类型不正确');                    return;                }                // 表格的表格范围,可用于判断表头是否数量是否正确                var fromTo = '';                // 遍历每张表读取                for (var sheet in workbook.Sheets) {                    if (workbook.Sheets.hasOwnProperty(sheet)) {                        fromTo = workbook.Sheets[sheet]['!ref'];                        console.log(fromTo);                        persons = persons.concat(XLSX.utils.sheet_to_json(workbook.Sheets[sheet]));                        // break; // 如果只取第一张表,就取消注释这行                    }                }                console.log(persons);            };            // 以二进制方式打开文件            fileReader.readAsBinaryString(files[0]);        });
 
 
 
原文章连接 
 
 
 

转载于:https://www.cnblogs.com/weimengduzun/p/9555161.html

你可能感兴趣的文章
phpstudy多站点配置好后index of/ 列表无法出现的解决
查看>>
70.打印所有Spring boot载入的bean【从零开始学Spring Boot】
查看>>
jvm compile
查看>>
linux内核SMP负载均衡浅析
查看>>
display的block、none、inline属性及解释
查看>>
新的Mac下如何配置开发者账号信息
查看>>
非阻塞socket的连接
查看>>
UITextField的代理方法
查看>>
无人驾驶相关数据集
查看>>
C 的大致运行原理。
查看>>
关于jsp和eclipse服务器端的相关配置和JS的区别
查看>>
JavaScript - 数据类型和变量
查看>>
TCP/IP:IP选项处理
查看>>
【网摘】检测 iframe 是否加载完成
查看>>
cocos2dx 3.x(动态改变精灵的背景图片)
查看>>
cocos2d-x JS 获取当前系统时间(解决屏幕双击点击事件)
查看>>
支付宝接入参考博客
查看>>
学习Spring中遇到关于BeanFactory及测试类的问题
查看>>
现实迷途 第七章 特殊客户
查看>>
找水王
查看>>