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

引言

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

第一部分:Excel 文件导出

1. 安装依赖

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

bash 复制代码
npm install [email protected] 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 的新特性,完成一些常见的前端任务。

相关推荐
東雪木16 分钟前
Web开发—Vue工程化
前端·javascript·vue.js·前端框架·web
全栈凯哥21 分钟前
ES6 (ECMAScript 2015) 详解
前端·ecmascript·es6
二狗子的翠花29 分钟前
vue-grid-layout实现拖拽修改工作台布局
前端·javascript·vue.js
想不明白的过度思考者32 分钟前
为了结合后端而学习前端的学习日志(1)——纯CSS静态卡片案例
前端·css·学习
未来之窗软件服务1 小时前
打开所在文件路径,鸿蒙系统,苹果macos,windows,android,linux —智能编程—仙盟创梦IDE
前端·ide·资源管理器·仙盟创梦ide
houzhizhen2 小时前
SQL JOIN 关联条件和 where 条件的异同
前端·数据库·sql
^小桃冰茶5 小时前
CSS知识总结
前端·css
运维@小兵5 小时前
vue注册用户使用v-model实现数据双向绑定
javascript·vue.js·ecmascript
巴巴_羊6 小时前
yarn npm pnpm
前端·npm·node.js
chéng ௹8 小时前
vue2 上传pdf,拖拽盖章,下载图片
前端·css·pdf