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 来触发重新渲染。

jQuery制作网页表格数据优化插件
jQuery制作网页表格数据优化插件

jQuery制作网页表格数据展示优化插件,固定的表头和表格的滚动条样式,这样的设计让表单更加清晰。

下载

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函数的用法,大家可以阅读本专题下面的文章。

922

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与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3099

2024.08.14

Java编译相关教程合集
Java编译相关教程合集

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

11

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

4

2026.01.21

无人机驾驶证报考 uom民用无人机综合管理平台官网
无人机驾驶证报考 uom民用无人机综合管理平台官网

无人机驾驶证(CAAC执照)报考需年满16周岁,初中以上学历,身体健康(矫正视力1.0以上,无严重疾病),且无犯罪记录。个人需通过民航局授权的训练机构报名,经理论(法规、原理)、模拟飞行、实操(GPS/姿态模式)及地面站训练后考试合格,通常15-25天拿证。

16

2026.01.21

热门下载

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

精品课程

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

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