React实现 Excel 文件导出与在线预览

引言

React 18 的发布带来了一系列全新的特性和改进,其中包括对并发渲染、状态管理等方面的增强。在这篇文章中,我们将利用 React 18 的强大功能,演示如何使用 React 18 编写 Excel 文件的导出与在线预览功能。

第一部分:Excel 文件导出

1. 安装依赖

首先,确保你的项目已经升级到 React 18,并安装最新版本的 xlsx 库。

bash 复制代码
npm install xlsx@0.17.1-alpha.3 react@18 react-dom@18 --save

2. 创建导出组件

创建一个名为 ExcelExport 的组件,并利用 react/jsx-concurrent-mode 特性实现并发渲染。

jsx 复制代码
import React, { unstable_ConcurrentMode as ConcurrentMode } from 'react';
import * as XLSX from 'xlsx';

const ExcelExport = () => {
  const exportToExcel = () => {
    const data = [
      ['姓名', '年龄'],
      ['Alice', 25],
      ['Bob', 30],
      ['Charlie', 22],
    ];

    const ws = XLSX.utils.aoa_to_sheet(data);
    const wb = XLSX.utils.book_new();
    XLSX.utils.book_append_sheet(wb, ws, 'Sheet1');

    XLSX.writeFile(wb, 'exported_data.xlsx');
  };

  return (
    <ConcurrentMode>
      <div>
        <button onClick={exportToExcel}>导出Excel</button>
      </div>
    </ConcurrentMode>
  );
};

export default ExcelExport;

3. 实现导出逻辑

exportToExcel 方法中,我们依然使用 xlsx 库创建工作簿并导出文件,与 React 18 的并发渲染特性无缝集成。

第二部分:在线预览 Excel 文件

1. 安装依赖

为了实现在线预览,我们依然使用 react-excel-renderer 库。

bash 复制代码
npm install react-excel-renderer --save

2. 创建预览组件

创建一个名为 ExcelPreview 的组件,并利用 React 18 的 Concurrent Mode 实现并发渲染。

jsx 复制代码
import React, { useState } from 'react';
import ReactDataSheet from 'react-datasheet';
import 'react-datasheet/lib/react-datasheet.css';
import { OutTable, ExcelRenderer } from 'react-excel-renderer';

const ExcelPreview = () => {
  const [dataLoaded, setDataLoaded] = useState(false);
  const [rows, setRows] = useState([]);
  const [cols, setCols] = useState([]);

  const fileHandler = (event) => {
    let fileObj = event.target.files[0];

    ExcelRenderer(fileObj, (err, resp) => {
      if (err) {
        console.log(err);
      } else {
        setDataLoaded(true);
        setCols(resp.cols);
        setRows(resp.rows);
      }
    });
  };

  return (
    <ConcurrentMode>
      <div>
        <input
          type="file"
          onChange={(event) => fileHandler(event)}
          style={{ padding: '10px' }}
        />
        {dataLoaded && (
          <ReactDataSheet
            data={rows}
            valueRenderer={(cell) => cell.value}
            sheetRenderer={(props) => <OutTable {...props} />}
          />
        )}
      </div>
    </ConcurrentMode>
  );
};

export default ExcelPreview;

3. 文件上传与在线预览

fileHandler 方法中,我们仍然使用 react-excel-renderer 从上传的Excel文件中提取数据,并将其渲染到 ReactDataSheet 中。这里也充分利用了 React 18 的 Concurrent Mode 特性,提升了渲染性能。

结语

通过这篇文章,我们学习了如何在 React 18 中实现 Excel 文件的导出和在线预览。React 18 带来的并发渲染特性能够更好地处理大规模数据,提高了性能和用户体验。希望这份指南帮助你更好地利用 React 18 的新特性,完成一些常见的前端任务。

相关推荐
你的人类朋友6 分钟前
说说git的变基
前端·git·后端
姑苏洛言9 分钟前
网页作品惊艳亮相!这个浪浪山小妖怪网站太治愈了!
前端
字节逆旅16 分钟前
nvm 安装pnpm的异常解决
前端·npm
Jerry31 分钟前
Compose 从 View 系统迁移
前端
IT码农-爱吃辣条1 小时前
Three.js 初级教程大全
开发语言·javascript·three.js
GIS之路1 小时前
2025年 两院院士 增选有效候选人名单公布
前端
四岁半儿1 小时前
vue,H5车牌弹框定制键盘包括新能源车牌
前端·vue.js
烛阴1 小时前
告别繁琐的类型注解:TypeScript 类型推断完全指南
前端·javascript·typescript
gnip1 小时前
工程项目中.env 文件原理
前端·javascript
JefferyXZF2 小时前
Next.js Server Actions 详解: 无缝衔接前后端的革命性技术(八)
前端·全栈·next.js