0

0

解决 React Hooks 和 MERN 栈中的数据未获取问题

DDD

DDD

发布时间:2025-09-17 18:34:01

|

772人浏览过

|

来源于php中文网

原创

解决 react hooks 和 mern 栈中的数据未获取问题

本文旨在解决 React Hooks 结合 MERN 开发中,由于 useEffect 依赖项缺失导致数据无法正确获取的问题。通过分析问题代码,我们将深入探讨如何正确使用 useEffect,并结合 useCallback 优化性能,同时提供代码示例,帮助开发者避免类似错误,构建更健壮的 React 应用。

在 React 开发中,useEffect Hook 用于处理副作用操作,如数据获取、订阅事件等。正确使用 useEffect 的依赖项数组至关重要,否则可能导致组件行为异常,例如数据未更新或无限循环。本文将以一个 MERN 栈项目中的巴士信息展示为例,详细讲解如何避免 useEffect 的常见错误,并优化代码性能。

理解 useEffect 的依赖项

useEffect 接收两个参数:一个回调函数和一个可选的依赖项数组。当依赖项数组中的任何一个值发生变化时,回调函数就会被执行。如果依赖项数组为空 [],则回调函数只会在组件挂载时执行一次。如果省略依赖项数组,则回调函数会在每次组件渲染后执行。

在提供的代码中,Home 组件使用 useEffect 获取巴士数据:

useEffect(() => {
    getBuses();
    //setSelectedBus();
  }, [])

控制台提示 "React Hook useEffect has a missing dependency: 'getBuses'"。这意味着 getBuses 函数在组件的生命周期内可能会发生变化,但 useEffect 并未追踪这种变化。因此,getBuses 可能使用了过时的状态或 props,导致数据获取不正确。

解决方案:添加依赖项

要解决这个问题,需要将 getBuses 添加到 useEffect 的依赖项数组中:

GemDesign
GemDesign

AI高保真原型设计工具

下载
useEffect(() => {
    getBuses();
}, [getBuses])

这样,当 getBuses 函数发生变化时,useEffect 就会重新执行,确保获取最新的数据。

优化:使用 useCallback

为了进一步优化代码,可以结合 useCallback Hook 来创建 getBuses 函数。useCallback 会返回一个 memoized 版本的函数,只有当依赖项发生变化时,才会重新创建函数。这可以避免不必要的函数重新创建,提高性能。

import React, { useEffect, useState, useCallback } from 'react'
import { useDispatch, useSelector } from 'react-redux'
import { axiosInstance } from '../helpers/axiosInstance';
import { HideLoading, ShowLoading } from '../redux/alertsSlice';
import { Col, Row, message } from 'antd';
import Bus from '../components/Bus';

function Home() {
  const { user } = useSelector(state => state.users)
  const [filters = {}, setFilters] = useState({});
  const dispatch = useDispatch();
  const [buses, setBuses] = useState([]);

  const getBuses = useCallback(async () => {
    dispatch(ShowLoading());
    axiosInstance.post("/api/buses/get-all-buses", filters) // Directly use filters
      .then((response) => {
        if (response?.data?.success) {
          setBuses(response.data.data);
        } else {
          message.error(response.data.message);
        }
      })
      .catch((error) => message.error(error.message))
      .finally(() => dispatch(HideLoading()));
  }, [filters, dispatch]); // Add dispatch to dependencies

  useEffect(() => {
    getBuses();
  }, [getBuses])

  const handleOnChange = useCallback(({ target: { name, value } }) => {
    setFilters((prevState) => ({ ...prevState, [name]: value }));
  }, []);

  return (
    
{buses.filter((bus) => bus.status === "Yet to start").map((bus) => ( ))}
) } export default Home

代码解释:

  1. useCallback(..., [filters, dispatch]): getBuses 函数现在使用 useCallback 包裹,依赖于 filters 和 dispatch。这意味着只有当 filters 或 dispatch 发生变化时,getBuses 才会重新创建。 并且直接将filters传递给了后端接口,避免了不必要的对象拷贝。
  2. useEffect(..., [getBuses]): useEffect 现在依赖于 getBuses。当 getBuses 函数发生变化时(即 filters 或 dispatch 发生变化),useEffect 重新执行,获取最新的巴士数据。
  3. useCallback(..., []): 使用useCallback创建handleOnChange 函数,并添加了动态的name属性,用于处理input的change事件。

注意事项

  • 确保 useEffect 的依赖项数组包含所有在回调函数中使用的、可能发生变化的值。
  • 使用 useCallback 优化函数,避免不必要的函数重新创建。
  • 仔细检查控制台的警告信息,它们通常能提供关于依赖项问题的线索。

总结

正确使用 useEffect 的依赖项数组是 React 开发中的一项重要技能。通过将所有必要的依赖项添加到数组中,并结合 useCallback 优化函数,可以避免数据获取错误,提高组件性能,并构建更健壮的 React 应用。本文通过一个 MERN 栈项目的实例,详细讲解了如何解决 useEffect 的常见问题,并提供了可复用的代码示例。希望这些信息能帮助开发者更好地理解和应用 React Hooks。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1072

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

148

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1050

2025.12.29

java接口相关教程
java接口相关教程

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

13

2026.01.19

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

394

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.11.24

c++ 根号
c++ 根号

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

42

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

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

46

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.1万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

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

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