欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React實(shí)現(xiàn)Excel文件的導(dǎo)出與在線預(yù)覽功能

 更新時(shí)間:2023年12月25日 09:59:47   作者:餃子不放糖  
這篇文章主要為大家詳細(xì)介紹了如何利用?React?18?的強(qiáng)大功能,演示如何使用?React?18?編寫(xiě)?Excel?文件的導(dǎo)出與在線預(yù)覽功能,需要的小伙伴可以參考下

引言

React 18 的發(fā)布帶來(lái)了一系列全新的特性和改進(jìn),其中包括對(duì)并發(fā)渲染、狀態(tài)管理等方面的增強(qiáng)。在這篇文章中,我們將利用 React 18 的強(qiáng)大功能,演示如何使用 React 18 編寫(xiě) Excel 文件的導(dǎo)出與在線預(yù)覽功能。

第一部分:Excel 文件導(dǎo)出

1. 安裝依賴(lài)

首先,確保你的項(xiàng)目已經(jīng)升級(jí)到 React 18,并安裝最新版本的 xlsx 庫(kù)。

npm install xlsx@0.17.1-alpha.3 react@18 react-dom@18 --save

2. 創(chuàng)建導(dǎo)出組件

創(chuàng)建一個(gè)名為 ExcelExport 的組件,并利用 react/jsx-concurrent-mode 特性實(shí)現(xiàn)并發(fā)渲染。

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}>導(dǎo)出Excel</button>
      </div>
    </ConcurrentMode>
  );
};

export default ExcelExport;

3. 實(shí)現(xiàn)導(dǎo)出邏輯

exportToExcel 方法中,我們依然使用 xlsx 庫(kù)創(chuàng)建工作簿并導(dǎo)出文件,與 React 18 的并發(fā)渲染特性無(wú)縫集成。

第二部分:在線預(yù)覽 Excel 文件

1. 安裝依賴(lài)

為了實(shí)現(xiàn)在線預(yù)覽,我們依然使用 react-excel-renderer 庫(kù)

npm install react-excel-renderer --save

2. 創(chuàng)建預(yù)覽組件

創(chuàng)建一個(gè)名為 ExcelPreview 的組件,并利用 React 18 的 Concurrent Mode 實(shí)現(xiàn)并發(fā)渲染。

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. 文件上傳與在線預(yù)覽

fileHandler 方法中,我們?nèi)匀皇褂?react-excel-renderer 從上傳的Excel文件中提取數(shù)據(jù),并將其渲染到 ReactDataSheet 中。這里也充分利用了 React 18 的 Concurrent Mode 特性,提升了渲染性能。

結(jié)語(yǔ)

通過(guò)這篇文章,我們學(xué)習(xí)了如何在 React 18 中實(shí)現(xiàn) Excel 文件的導(dǎo)出和在線預(yù)覽。React 18 帶來(lái)的并發(fā)渲染特性能夠更好地處理大規(guī)模數(shù)據(jù),提高了性能和用戶(hù)體驗(yàn)。

到此這篇關(guān)于React實(shí)現(xiàn)Excel文件的導(dǎo)出與在線預(yù)覽功能的文章就介紹到這了,更多相關(guān)React Excel導(dǎo)出與預(yù)覽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React配置多個(gè)代理實(shí)現(xiàn)數(shù)據(jù)請(qǐng)求返回問(wèn)題

    React配置多個(gè)代理實(shí)現(xiàn)數(shù)據(jù)請(qǐng)求返回問(wèn)題

    這篇文章主要介紹了React之配置多個(gè)代理實(shí)現(xiàn)數(shù)據(jù)請(qǐng)求返回問(wèn)題,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • 從零開(kāi)始搭建webpack+react開(kāi)發(fā)環(huán)境的詳細(xì)步驟

    從零開(kāi)始搭建webpack+react開(kāi)發(fā)環(huán)境的詳細(xì)步驟

    這篇文章主要介紹了從零開(kāi)始搭建webpack+react開(kāi)發(fā)環(huán)境的詳細(xì)步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • React Router v4 入坑指南(小結(jié))

    React Router v4 入坑指南(小結(jié))

    這篇文章主要介紹了React Router v4 入坑指南(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • 詳解React?Fiber架構(gòu)原理

    詳解React?Fiber架構(gòu)原理

    Fiber?可以理解為一個(gè)執(zhí)行單元,每次執(zhí)行完一個(gè)執(zhí)行單元,React?Fiber就會(huì)檢查還剩多少時(shí)間,如果沒(méi)有時(shí)間則將控制權(quán)讓出去,然后由瀏覽器執(zhí)行渲染操作,這篇文章主要介紹了React?Fiber架構(gòu)原理剖析,需要的朋友可以參考下
    2022-08-08
  • React Hooks使用常見(jiàn)的坑

    React Hooks使用常見(jiàn)的坑

    React Hooks 是 React 16.8 引入的新特性,允許我們?cè)诓皇褂?Class 的前提下使用 state 和其他特性。接下來(lái)通過(guò)本文給大家分享React Hooks使用避坑指南,一起學(xué)習(xí)下吧
    2021-06-06
  • Suspense對(duì)React的意義及作用解析

    Suspense對(duì)React的意義及作用解析

    這篇文章主要為大家介紹了Suspense對(duì)React的意義及作用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • React如何立即更新DOM

    React如何立即更新DOM

    這篇文章主要介紹了React如何立即更新DOM問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 深入解析React?Hooks?閉包陷阱

    深入解析React?Hooks?閉包陷阱

    這篇文章主要為大家介紹了React Hooks閉包陷阱的深入探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • React日期時(shí)間顯示組件的封裝方法

    React日期時(shí)間顯示組件的封裝方法

    這篇文章主要為大家詳細(xì)介紹了React日期時(shí)間顯示組件的封裝方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • React的三大屬性你都知道嗎

    React的三大屬性你都知道嗎

    這篇文章主要為大家詳細(xì)介紹了React的三大屬性,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02

最新評(píng)論