Vue实现Excel预览功能

Vue实现Excel预览功能

前言:

项目中经常能遇到要求预览excel文件的需求,下面分享一下常用的方法以及可能遇到的问题。

使用场景:

通过解析excel功能,实现PDF导入时的预览

首先我们用到了XLSX(sheetJs) 这个库来处理Excel类型的文件

地址:

docs.sheetjs.com/

www.npmjs.com/package/xls...

支持大部分的现代浏览器版本

具体使用:

下载: npm i xlsx

首先我们获取一Excel类型的文件。

这里我直接用了el-upload组件返回的文件

然后使用FileReader读取文件,注册初始化onload方法,并且在其onload方法中使用xlsx库处理文件;

  • 首先使用xlsx的read方法,配置处理的详情。
php 复制代码
    const workbook = XLSX.read(data, {
      type: "binary",
      cellText: false,
      cellDates: true,
    });
  • 再轮询读取文件
kotlin 复制代码
    for (let sheet in workbook.Sheets) {
      //循环读取每个文件
      const header = XLSX.utils.sheet_to_json(workbook.Sheets[sheet], {
        header: 1,
      });
​
      const sheetArray = XLSX.utils.sheet_to_json(
        workbook.Sheets[sheet],
        // 配置单元的数据转换方法,dateNF不生效
        { raw: true, cellDates: true, dateNF: "yyyy/mm/dd" }
      );
​
      //若当前sheet没有数据,则continue
      if (sheetArray.length == 0) {
        continue;
      }
      this.tableHeader = header[0];
      this.handleNetX(sheetArray, header[0]);
    }
  } catch (e) {
    this.$message.warning("上传失败");
  }

注意sheet_to_json方法中此时cellDates配置为true之后,如果excel文件内的数据类型为时间,会被转成Date格式。

官方文档中允许配置dateNF来进行时间格式化,但是实际使用起来并没有效果。

所以针对时间格式的处理,笔者这里直接转为Date格式,在后续过程中进行了手动处理。

我们初始化load方法后,将excel文件源文件,转为bolb格式,在塞给fileReader.readAsBinaryString,进行文件处理方法的执行。

ini 复制代码
      const blob = new Blob([file.raw]);
      fileReader.readAsBinaryString(blob);

最后轮询sheetArray来进行数据的二次处理,最后得到前端可以使用的Array类型的文件,展示在页面中或者展示在表单中。

时间格式处理

处理时间的方法写的比较简单,主要就是判断了Date的object类型,来格式化日期类型

ini 复制代码
    handleNetX(sheetArray, header) {
      const totalTable = [];
      for (let index in sheetArray) {
        let row = {};
        header.map(index1 => {
          const tempKey = this.mapTableTitle[index1];
​
          if (typeof sheetArray[index][index1] === "object") {
            row[tempKey] = this.handleExcelDate(sheetArray[index][index1]);
          } else {
            row[tempKey] = sheetArray[index][index1];
          }
        });
        totalTable.push(row);
      }
      this.tableData = totalTable;
    },
​
​
    handleExcelDate(date) {
      if (!date) {
        return;
      }
      return formatDate(date.getTime(), "YYYY/MM/DD");
    },

代码总结:

ini 复制代码
    async handleChangePre(file) {
      this.file = file;
      this.showResult = false;
​
      const fileReader = new FileReader();
​
      fileReader.onload = ev => {
        try {
          const data = ev.target.result;
​
          const workbook = XLSX.read(data, {
            type: "binary",
            cellText: false,
            cellDates: true,
          });
​
          for (let sheet in workbook.Sheets) {
            //循环读取每个文件
            const header = XLSX.utils.sheet_to_json(workbook.Sheets[sheet], {
              header: 1,
            });
​
            const sheetArray = XLSX.utils.sheet_to_json(
              workbook.Sheets[sheet],
              { raw: true, cellDates: true, dateNF: "yyyy/mm/dd" }
            );
​
            //若当前sheet没有数据,则continue
            if (sheetArray.length == 0) {
              continue;
            }
            this.tableHeader = header[0];
            console.log(sheetArray, "sheetArray");
            this.handleNetX(sheetArray, header[0]);
          }
        } catch (e) {
          this.$message.warning("上传失败");
        }
      };
      const blob = new Blob([file.raw]);
      fileReader.readAsBinaryString(blob);
    },
相关推荐
Southern Wind5 分钟前
我在 Vue3 项目里接入 AI 后,发现前端完全变了
前端·人工智能·状态模式
Bigger6 分钟前
我手搓了一个开源版 Claude Code (mini-cc)
前端·ai编程·claude
qq43569470110 分钟前
JavaWeb03
前端·css·html
Alice-YUE12 分钟前
ai对话平台流式响应输出怎么实现?
前端·笔记·ai·语言模型
一个public的class16 分钟前
前后端 + Nginx + Gateway + K8s 全链路架构图解
前端·后端·nginx·kubernetes·gateway
胡志辉的博客20 分钟前
网络七层到底怎么落到一次前端请求上:从浏览器到网卡,再到远端服务器
服务器·前端·网络
小比特_蓝光21 分钟前
从环境变量到进程地址空间:Linux系统学习笔记
前端·chrome
亿元程序员22 分钟前
海外这个新游好玩?手把手带你实战一个!
前端
M ? A23 分钟前
Vue slot 插槽转 React:VuReact 怎么处理?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
a11177626 分钟前
演唱会3D选座网页(HTML 开源)
前端·3d·html