0

0

在 React 表格中展示数组数据

聖光之護

聖光之護

发布时间:2025-08-19 17:08:36

|

822人浏览过

|

来源于php中文网

原创

在 react 表格中展示数组数据

本文旨在指导开发者如何在 React 表格中有效地展示从 API 获取的数组数据。通过将数组状态化,并在 useEffect 钩子中异步更新状态,我们可以确保表格能够正确渲染动态数据。本文提供详细的代码示例和解释,帮助你避免常见的渲染问题,并构建可维护的 React 组件。

在 React 应用中,经常需要从后端 API 获取数据并在表格中展示。本文将介绍如何正确地处理和渲染数组数据到 React 表格中,避免常见的渲染问题。

1. 使用 State 管理数组数据

在 React 中,要使组件能够响应数据的变化,需要将数据存储在 state 中。 这样,当数据更新时,React 会重新渲染组件,从而更新表格的内容。

import React, { useState, useEffect } from 'react';
import axios from 'axios';

function MyTable() {
  const [ure, setUre] = useState([]);

  // ...
}

这里,我们使用 useState 钩子创建了一个名为 ure 的状态变量,初始值为空数组 []。 setUre 函数用于更新 ure 的值。

2. 在 useEffect 中获取和更新数据

useEffect 钩子用于处理副作用,例如从 API 获取数据。当组件挂载后,useEffect 会执行回调函数。

  useEffect(() => {
    axios
      .get("/api/listUre")
      .then((res) => {
        console.log(res.data);
        // 正确更新状态的方式
        setUre(res.data);
      })
      .catch((error) => {
        // 处理错误
        console.log(error);
      })
      .finally(() => {
        // 可选:在请求完成后执行的操作
      });
  }, []); // 空依赖数组表示只在组件挂载时执行一次

在这个例子中,我们使用 axios 发起 GET 请求,从 /api/listUre 获取数据。当请求成功时,我们使用 setUre 函数将获取到的数据更新到 ure 状态中。注意,直接将 res.data 赋值给 ure,而不是使用 ure.push()。 ure.push() 是直接修改状态,这在 React 中是不推荐的。 应该使用 setUre 来触发重新渲染。

I-Shop购物系统
I-Shop购物系统

部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/

下载

3. 在表格中渲染数据

有了状态化的数组数据,我们就可以在表格中渲染它了。

  return (
    
        {ure.map((obj, index) => (
          
        ))}
      
Class ID Class ID (Duplicate) Name
{obj.class_id} {obj.class_id} My Name
);

这里,我们使用 ure.map() 方法遍历数组中的每个对象,并为每个对象创建一个表格行

。 key 属性对于 React 识别列表中的元素至关重要,它可以帮助 React 更有效地更新 DOM。

不需要使用 ure.length > 0 && 来判断数组是否为空。 map() 方法会自动处理空数组的情况,不会渲染任何内容。

4. 完整代码示例

import React, { useState, useEffect } from 'react';
import axios from 'axios';

function MyTable() {
  const [ure, setUre] = useState([]);

  useEffect(() => {
    axios
      .get("/api/listUre")
      .then((res) => {
        console.log(res.data);
        setUre(res.data);
      })
      .catch((error) => {
        console.log(error);
      })
      .finally(() => {
      });
  }, []);

  return (
    
        {ure.map((obj, index) => (
          
        ))}
      
Class ID Class ID (Duplicate) Name
{obj.class_id} {obj.class_id} My Name
); } export default MyTable;

总结

通过将数组数据存储在 state 中,并在 useEffect 钩子中异步更新状态,我们可以确保 React 表格能够正确渲染动态数据。记住以下几点:

  • 使用 useState 管理数组数据。
  • 使用 useEffect 获取和更新数据。
  • 使用 map() 方法遍历数组并渲染表格行。
  • 为每个表格行添加唯一的 key 属性。
  • 使用 setUre 来更新状态,而不是直接修改状态。

遵循这些步骤,你就可以轻松地在 React 表格中展示数组数据,并构建可维护的 React 组件。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

923

2023.09.19

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

60

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

40

2025.11.27

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3162

2024.08.14

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

53

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

28

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号