React 前端通过组件实现 “下载 Excel模板” 和 “上传 Excel 文件读取内容生成对象数组”

news/2024/11/8 7:38:07 标签: 前端, react.js, excel

文章目录

  • 一、Excel 模板下载
    • 01、代码示例
  • 二、Excel 文件上传
    • 01、文件展示
    • 02、示例代码
    • 03、前端样式展示
    • 04、数据结果展示
  • 三、完整代码

本文的业务需求是建立在批量导入数据的情况下,普通组件只能少量导入,数据较多的情况都会选择 Excel 数据导入,这就涉及到下载 Excel 模板和上传带有数据的Excel 文件,读取数据进行后一步的存储操作。

本文讲解了两部分内容:

  • 如何在 React 前端使用 UI 组件(这里使用button 按钮 和 input 输入框的组合样式)上传一个 Excel 文件,并读取文件内容转成可使用的 json 对象数组的数据格式。
  • 如何在 React 前端使用 UI 组件(这里使用button 按钮)下载一个 Excel 文件模板,用于对上传 Excel 做准备。

一、Excel 模板下载

先准备好模板文件,放在了 React 项目的 public 文件夹下,通过按钮的方式让用户点击并下载该文件。

01、代码示例

这里有两个很容易出错的问题:

  • 模板名字,const templateUrl = '/template.xlsx'; 路径引用中名字出错会出现找不到资源的问题,表现结果是刷新界面。
  • 路径问题,const templateUrl = '/template.xlsx'; 这个路径是正确的。下面两个示例在运行时不会工作,因为 public 文件夹的内容在构建时被复制到根目录。
    • const templateUrl = './public/template.xlsx';
    • const templateUrl = '../../public/template.xlsx';

只要你的 template.xlsx 文件位于 public 文件夹中,并且你使用 /template.xlsx 这个绝对路径来引用它,你就可以在 React 项目的任何组件中通过点击事件来触发下载,而无需担心组件文件的位置。

import React from 'react';

const downExcelTemplate: React.FC = () => {
	// 模板文件的URL(由于放在public文件夹中,所以可以直接通过/来访问)  
	const templateUrl = '/template.xlsx';  
	
	// 处理下载的函数  
	const handleDownload = () => {  
		// 创建一个隐藏的<a>标签并触发点击事件来下载文件  
    	const link = document.createElement('a');  
    	link.href = templateUrl;  
    	link.download = '测试.xlsx'; // 可以设置下载时的文件名  
    	document.body.appendChild(link);  
    	link.click();  
    	document.body.removeChild(link); // 下载后移除<a>标签  
	};  
  
	return (<div>  
		<button onClick={handleDownload} className="download-button">  
			模板下载
		</button>  
	</div>);  
}  
  
export default downExcelTemplate;

现在就可以点击模板下载弹出下载文件的界面了。
样式

二、Excel 文件上传

01、文件展示

下图是用模板文件填写的数据文件图片。

Excel 文件

02、示例代码

完整代码包装成了一个组件。需要注意,React 本身不支持读取 Excel 文件,需要导入依赖,在项目的 package.json 中引入依赖,我的引入的 xlsx 依赖版本如下:

"xlsx": "^0.18.5",

使用的是 button 按钮点击上传的方式,这样可以减少样式调整,重点是 input 输入框的 style 属性设置一个 display: "none"

import React from 'react';
import * as XLSX from 'xlsx';

const ReadExcelWord: React.FC = () => {

    const handleFileChange = (event: any) => {
        const inputFile = event.target.files[0];
        if (inputFile){
            const reader = new FileReader();
            reader.onload = (e: any) => {
                const data = new Uint8Array(e.target?.result);
                const workbook = XLSX.read(data, {type: 'array'});
                // 只读取第一个sheet
                const firstSheetName = workbook.SheetNames[0];
                const workSheet = workbook.Sheets[firstSheetName];
                const jsonData = XLSX.utils.sheet_to_json(workSheet, { header: 1});
                console.log("jsonData", jsonData);
            };
            reader.readAsArrayBuffer(inputFile); 
        }
    }

	// input 输入框的 id = "upfile" 很重要
    const handleButtonClick = () => {
    	let upExcel = document.getElementById("upfile");
    	upExcel?.click();
    }
    
	return (<div>
		<button onClick={handleButtonClick}>上传</button>
		<input 
			id="upfile" 
			type="file" 
			style={{ display: "none" }} 
			accept=".xlsx" 
			onChange={handleFileChange} 
		/>
	</div>);
};

export default ReadExcelWord;

03、前端样式展示

在这里插入图片描述

04、数据结果展示

json对象结果

三、完整代码

import React from 'react';
import * as XLSX from 'xlsx';

const ReadExcelWord: React.FC = () => {

    const handleFileChange = (event: any) => {
        const inputFile = event.target.files[0];
        if (inputFile) {
            const reader = new FileReader();
            reader.onload = (e: any) => {
                const data = new Uint8Array(e.target?.result);
                const workbook = XLSX.read(data, {type: 'array'});
                // 只读取第一个sheet
                const firstSheetName = workbook.SheetNames[0];
                const workSheet = workbook.Sheets[firstSheetName];
                const jsonData = XLSX.utils.sheet_to_json(workSheet, { header: 1});
                console.log("jsonData", jsonData);
            };
            reader.readAsArrayBuffer(inputFile); 
        }
    }

	// input 输入框的 id = "upfile" 很重要
    const handleButtonClick = () => {
    	let upExcel = document.getElementById("upfile");
    	upExcel?.click();
    }
    
	// 模板文件的URL(由于放在public文件夹中,所以可以直接通过/来访问)  
	const templateUrl = '/template.xlsx';  
	
	// 处理下载的函数  
	const handleDownload = () => {  
		// 创建一个隐藏的<a>标签并触发点击事件来下载文件  
    	const link = document.createElement('a');  
    	link.href = templateUrl;  
    	link.download = '测试.xlsx'; // 可以设置下载时的文件名  
    	document.body.appendChild(link);  
    	link.click();  
    	document.body.removeChild(link); // 下载后移除<a>标签  
	};  
  
	return (<div>
		<button onClick={handleButtonClick}>上传</button>
		<input 
			id="upfile" 
			type="file" 
			style={{ display: "none" }} 
			accept=".xlsx" 
			onChange={handleFileChange} 
		/>
		<button onClick={handleDownload} className="download-button">  
			模板下载
		</button> 
	</div>);
};

export default ReadExcelWord;

http://www.niftyadmin.cn/n/5743524.html

相关文章

Vue 项目中为何选择 TSX 而非传统 .vue 文件

近年来&#xff0c;Vue 项目中使用 TSX&#xff08;TypeScript JSX&#xff09;的写法逐渐增多&#xff0c;尤其在 TypeScript 项目中。 1. TSX 与 Vue 的结合背景 1、Vue 3 和 TypeScript Vue 3 从设计之初便更好地支持 TypeScript。Vue 3 使用了 TypeScript 重写核心&…

qt QErrorMessage详解

1、概述 QErrorMessage是Qt框架中用于显示错误消息的一个对话框类。它提供了一个简单的模态对话框&#xff0c;用于向用户显示错误或警告消息。QErrorMessage通常用于应用程序中&#xff0c;当需要向用户报告错误但不希望中断当前操作时。它提供了一个标准的错误消息界面&…

Neo4j 和 Python 初学者指南:如何使用可选关系匹配优化 Cypher 查询

Neo4j 和 Python 初学者指南&#xff1a;如何使用可选关系匹配优化 Cypher 查询 查询需求分析目标查询结构 编写 Cypher 查询查询解析OPTIONAL MATCH 和 COALESCE 的作用 在 Python 中使用 Neo4j 驱动执行查询使用 neo4j 驱动的 Python 示例代码代码解析示例输出 总结 在使用 N…

漏洞分析 | Spring Framework路径遍历漏洞(CVE-2024-38816)

漏洞概述 VMware Spring Framework是美国威睿&#xff08;VMware&#xff09;公司的一套开源的Java、JavaEE应用程序框架。该框架可帮助开发人员构建高质量的应用。 近期&#xff0c;网宿安全演武实验室监测到Spring Framework在特定条件下&#xff0c;存在目录遍历漏洞&…

【SQL实验】高级查询(难点.三)含附加数据库操作

完整代码在文章末尾【代码是自己的解答&#xff0c;并非标准答案&#xff0c;也有可能写错&#xff0c;文中可能会有不准确或待完善之处&#xff0c;恳请各位读者不吝批评指正&#xff0c;共同促进学习交流】 将素材中的“学生管理”数据库附加到SQL SERVER中&#xff0c;完成以…

简单了解一下 TypeScript 的泛型

在 TypeScript (TS) 中&#xff0c;泛型是一个强大且灵活的工具&#xff0c;用于编写具有更高可复用性和类型安全性的代码。泛型允许我们在声明时将类型作为参数传入&#xff0c;使函数、接口和类能在不同的数据类型下复用&#xff0c;而无需重新编写逻辑。 1. 泛型的基本语法…

论文《基于柔顺控制的智能神经导航手术机器人系统设计》文献阅读分析报告

论文报告&#xff1a;基于卷积神经网络的手术机器人控制系统设计 摘要 本研究针对机器人辅助微创手术中定向障碍和缺乏导航信息的问题&#xff0c;设计了一种智能控制导航手术机器人系统。该系统采用可靠和安全的定位技术、7自由度机械臂以及避免关节角度限制的逆运动学控制策…

Android CCodec Codec2 (二十)C2Buffer与Codec2Buffer

在阅读Codec2框架代码时&#xff0c;我们可能会发现好几个名称中都带有“buffer”的类&#xff0c;如MediaCodecBuffer、ABuffer、CCodecBuffers、Codec2Buffer以及C2Buffer。它们分别是什么&#xff1f;各自承担着什么功能&#xff1f;它们之间有何联系&#xff1f;本文将围绕…