XLSX插件使用 — 导入导出(含中文表头)(React+Antd 对上传表格做数据格式验证)

本文介绍了在React项目中,使用js-xlsx库实现前端导出Excel,并对上传的表格数据进行格式验证。详细讲解了如何处理包含中文表头的数据,以及简单导入和数据验证的实现方法。
摘要由CSDN通过智能技术生成

需求说明

1.需要前端做数据导出(非调用接口)
2.需要对上传的表格数据做验证,不通过验证需要提示格式不正确,阻拦上传

技术栈介绍

React+Antdesign+XLSX

js-xlsx 介绍

SheetJS出品的js-xlsx是一款非常方便的只需要纯JS即可读取和导出excel的工具库,功能强大,支持格式众多,支持xls、xlsx、ods(一种OpenOffice专有表格文件格式)等十几种格式。

GitHub地址:https://github.com/SheetJS/sheetjs

官网地址:https://sheetjs.com/

React使用文档:https://docs.sheetjs.com/docs/demos/frontend/react

导出的简单使用

首先插件的几个重要的名词对应如下图

在这里插入图片描述

根据数据类型,写法可分为

  1. 纯数组

    /**
     * 导出 excel 文件
     * @param array JSON 数组
     * @param sheetName 第一张表名
     * @param fileName 文件名
     */
    export function exportExcelFile(array: any[], sheetName = '表1', fileName = 'example.xlsx') {
         
      const jsonWorkSheet = xlsx.utils.json_to_sheet(array);
      const workBook: WorkBook = {
         
        SheetNames: [sheetName],
        Sheets: {
         
          [sheetName]: jsonWorkSheet,
        }
      };
      return xlsx.writeFile(workBook, fileName);
    }
    
  2. 对象数组(后端返回的数组是一堆对象)(第一行为中文表头

      export function exportExcelFile(array: any[], sheetName = '表1', fileName = 'example.xlsx') {
         
        // 属性名数组
        const header = ['name', 'age', 'addr'];
        <
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
前端接收并导出后端导出的Excel文件,也可以使用`xlsx`和`file-saver`库来实现。 首先,需要使用`fetch`或`axios`等网络请求库向后端请求Excel文件,并将返回的二进制流进行解析。可以使用`xlsx`库的`read`方法将二进制流转换为JSON格式的数据。示例代码如下: ```javascript import { read } from 'xlsx'; import { saveAs } from 'file-saver'; // ... fetch(url, { responseType: 'blob' }).then(res => { const reader = new FileReader(); reader.onload = () => { const data = new Uint8Array(reader.result); const workbook = read(data, { type: 'array' }); // 处理表格数据 // ... // 导出表格数据 const excelBuffer = write(workbook, { type: 'array', bookType: 'xlsx' }); const excelBlob = new Blob([excelBuffer], { type: 'application/octet-stream' }); saveAs(excelBlob, /* 指定的文件名 */); }; reader.readAsArrayBuffer(res.data); }); ``` 以上代码中,`fetch`请求的响应数据类型设置为`blob`,表示返回的是二进制流。接收到响应数据后,使用`FileReader`将二进制流转换为数组缓冲区,再使用`xlsx`库的`read`方法将数组缓冲区转换为JSON格式的数据。接下来根据具体需求进行表格数据处理,并使用`write`方法将数据转换为Excel文件的二进制流,最后使用`file-saver`库的`saveAs`方法将二进制流导出为Excel文件。 需要注意的是,在导出Excel文件时,需要设置正确的文件类型和文件名,否则可能会导致文件无法打开或文件名不符合预期。 以上是一个简单的接收和导出Excel文件的流程,具体实现还需要根据具体情况进行相应的调整。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值