在React中使用Antd上傳并讀取Excel文件的詳細(xì)步驟
安裝依賴
首先,你需要安裝xlsx
庫和antd
庫:
npm install xlsx antd
創(chuàng)建React組件
接下來,創(chuàng)建一個(gè)React組件來處理文件上傳和讀取Excel文件。
import React, { useState } from 'react'; import { Upload, Button, message } from 'antd'; import XLSX from 'xlsx'; const ExcelUploader = () => { const [data, setData] = useState([]); const handleUpload = ({ file }) => { const reader = new FileReader(); reader.onload = (event) => { try { const binaryString = event.target.result; const workbook = XLSX.read(binaryString, { type: 'binary' }); const sheetName = workbook.SheetNames[0]; const sheet = workbook.Sheets[sheetName]; const jsonData = XLSX.utils.sheet_to_json(sheet); setData(jsonData); message.success('文件上傳成功'); } catch (error) { message.error('文件讀取失敗,請檢查文件格式是否正確'); console.error('讀取文件失敗', error); } }; reader.readAsBinaryString(file); }; const beforeUpload = (file) => { const validFormats = ['application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'application/vnd.ms-excel']; if (!validFormats.includes(file.type)) { message.error('請選擇一個(gè)有效的Excel文件'); return false; } return true; }; return ( <div> <Upload beforeUpload={beforeUpload} customRequest={handleUpload} showUploadList={false} > <Button icon="upload">上傳Excel文件</Button> </Upload> <pre>{JSON.stringify(data, null, 2)}</pre> </div> ); }; export default ExcelUploader;
代碼解釋
安裝與引入:
- 使用
npm install xlsx antd
安裝xlsx
和antd
庫。 - 在React組件中引入
Upload
、Button
、message
組件和XLSX
庫:
- 使用
import { Upload, Button, message } from 'antd'; import XLSX from 'xlsx';
文件上傳處理:
- 使用
Upload
組件創(chuàng)建一個(gè)文件上傳按鈕。 beforeUpload
函數(shù)用于校驗(yàn)文件格式,確保用戶上傳的是有效的Excel文件。customRequest
函數(shù)用于處理文件上傳邏輯,讀取文件內(nèi)容并轉(zhuǎn)換為JSON格式。
- 使用
讀取Excel文件:
- 使用
FileReader
對象讀取用戶選擇的文件。readAsBinaryString
方法將文件內(nèi)容讀取為二進(jìn)制字符串。 - 使用
XLSX.read
方法讀取二進(jìn)制字符串,并將其轉(zhuǎn)換為工作簿對象。 - 獲取第一個(gè)工作表的名稱和內(nèi)容。
- 使用
XLSX.utils.sheet_to_json
方法將工作表的內(nèi)容轉(zhuǎn)換為JSON格式。
- 使用
展示數(shù)據(jù):
- 使用
<pre>{JSON.stringify(data, null, 2)}</pre>
將讀取到的數(shù)據(jù)以格式化的JSON形式展示在頁面上。
- 使用
樣式設(shè)置
為了使上傳按鈕更符合Ant Design的樣式規(guī)范,可以使用Ant Design的預(yù)設(shè)樣式類。以下是一個(gè)示例,展示如何使用Ant Design的樣式類來美化上傳按鈕:
import React, { useState } from 'react'; import { Upload, Button, message } from 'antd'; import XLSX from 'xlsx'; import './ExcelUploader.css'; // 引入自定義樣式文件 const ExcelUploader = () => { const [data, setData] = useState([]); const handleUpload = ({ file }) => { const reader = new FileReader(); reader.onload = (event) => { try { const binaryString = event.target.result; const workbook = XLSX.read(binaryString, { type: 'binary' }); const sheetName = workbook.SheetNames[0]; const sheet = workbook.Sheets[sheetName]; const jsonData = XLSX.utils.sheet_to_json(sheet); setData(jsonData); message.success('文件上傳成功'); } catch (error) { message.error('文件讀取失敗,請檢查文件格式是否正確'); console.error('讀取文件失敗', error); } }; reader.readAsBinaryString(file); }; const beforeUpload = (file) => { const validFormats = ['application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'application/vnd.ms-excel']; if (!validFormats.includes(file.type)) { message.error('請選擇一個(gè)有效的Excel文件'); return false; } return true; }; return ( <div className="upload-container"> <Upload beforeUpload={beforeUpload} customRequest={handleUpload} showUploadList={false} > <Button type="primary" icon="upload">上傳Excel文件</Button> </Upload> <pre className="data-preview">{JSON.stringify(data, null, 2)}</pre> </div> ); }; export default ExcelUploader;
自定義樣式文件 ExcelUploader.css
.upload-container { margin: 20px; text-align: center; } .data-preview { margin-top: 20px; background-color: #f0f0f0; padding: 10px; border-radius: 4px; overflow: auto; max-height: 400px; }
代碼解釋
自定義樣式文件:
- 創(chuàng)建一個(gè)
ExcelUploader.css
文件,定義上傳按鈕和數(shù)據(jù)預(yù)覽區(qū)域的樣式。 - 使用
className
屬性將自定義樣式應(yīng)用到React組件中。
- 創(chuàng)建一個(gè)
Ant Design樣式類:
- 使用
Button
組件的type="primary"
屬性,使按鈕具有Ant Design的主色調(diào)。 - 使用
icon="upload"
屬性,添加上傳圖標(biāo)。
- 使用
總結(jié)
通過使用antd
的Upload
組件和xlsx
庫,你可以在React項(xiàng)目中高效地實(shí)現(xiàn)Excel文件的上傳和讀取功能。同時(shí),通過自定義樣式文件,可以確保組件的樣式符合Ant Design的設(shè)計(jì)規(guī)范。
到此這篇關(guān)于在React中使用Antd上傳并讀取Excel文件的詳細(xì)步驟的文章就介紹到這了,更多相關(guān)React使用Antd上傳并讀取Excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react實(shí)現(xiàn)復(fù)選框全選和反選組件效果
這篇文章主要為大家詳細(xì)介紹了react實(shí)現(xiàn)復(fù)選框全選和反選組件效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08react性能優(yōu)化useMemo與useCallback使用對比詳解
這篇文章主要為大家介紹了react性能優(yōu)化useMemo與useCallback使用對比詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08React 項(xiàng)目中動(dòng)態(tài)設(shè)置環(huán)境變量
本文主要介紹了React 項(xiàng)目中動(dòng)態(tài)設(shè)置環(huán)境變量,本文將介紹兩種常用的方法,使用 dotenv 庫和通過命令行參數(shù)傳遞環(huán)境變量,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04react實(shí)現(xiàn)組件狀態(tài)緩存的示例代碼
本文主要介紹了react實(shí)現(xiàn)組件狀態(tài)緩存的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02React中useCallback useMemo使用方法快速精通
在React函數(shù)組件中,當(dāng)組件中的props發(fā)生變化時(shí),默認(rèn)情況下整個(gè)組件都會(huì)重新渲染。換句話說,如果組件中的任何值更新,整個(gè)組件將重新渲染,包括沒有更改values/props的函數(shù)/組件。在react中,我們可以通過memo,useMemo以及useCallback來防止子組件的rerender2023-02-02React特征Form?單向數(shù)據(jù)流示例詳解
這篇文章主要為大家介紹了React特征Form?單向數(shù)據(jù)流示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09TypeScript在React中的應(yīng)用技術(shù)實(shí)例解析
這篇文章主要為大家介紹了TypeScript在React中的應(yīng)用技術(shù)實(shí)例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04react-beautiful-dnd 實(shí)現(xiàn)組件拖拽功能
這篇文章主要介紹了react-beautiful-dnd 實(shí)現(xiàn)組件拖拽功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08Next+React項(xiàng)目啟動(dòng)慢刷新慢的解決方法小結(jié)
本文主要介紹了Next+React項(xiàng)目啟動(dòng)慢刷新慢的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-04-04ReactJS實(shí)現(xiàn)表單的單選多選和反選的示例
本篇文章主要介紹了ReactJS實(shí)現(xiàn)表單的單選多選和反選的示例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10