在实际开发中,经常会遇到导入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文件的内容分析转换,已经有了比较成熟的解决方案:js-xlsx 

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

 

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

  1. <input type="file" id="excel-file">

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

  1. <script type="text/javascript" src="xlsx.core.min.js"></script>

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

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

复制代码
复制代码
  1. $(\'#excel-file\').change(function(e) {
  2. var files = e.target.files;
  3.  
  4. var fileReader = new FileReader();
  5. fileReader.onload = function(ev) {
  6. try {
  7. var data = ev.target.result,
  8. workbook = XLSX.read(data, {
  9. type: \'binary\'
  10. }), // 以二进制流方式读取得到整份excel表格对象
  11. persons = []; // 存储获取到的数据
  12. } catch (e) {
  13. console.log(\'文件类型不正确\');
  14. return;
  15. }
  16.  
  17. // 表格的表格范围,可用于判断表头是否数量是否正确
  18. var fromTo = \'\';
  19. // 遍历每张表读取
  20. for (var sheet in workbook.Sheets) {
  21. if (workbook.Sheets.hasOwnProperty(sheet)) {
  22. fromTo = workbook.Sheets[sheet][\'!ref\'];
  23. console.log(fromTo);
  24. persons = persons.concat(XLSX.utils.sheet_to_json(workbook.Sheets[sheet]));
  25. // break; // 如果只取第一张表,就取消注释这行
  26. }
  27. }
  28.  
  29. console.log(persons);
  30. };
  31.  
  32. // 以二进制方式打开文件
  33. fileReader.readAsBinaryString(files[0]);
  34. });



 
 
 
 
 
 

版权声明:本文为weimengduzun原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/weimengduzun/p/9555161.html