0

0

如何使用useState和useEffect管理状态?

冰火之心

冰火之心

发布时间:2026-01-15 14:23:46

|

531人浏览过

|

来源于php中文网

原创

React函数组件需用useState管理状态、useEffect处理副作用:useState声明状态并更新触发重渲染;useEffect执行数据获取等操作,支持依赖数组控制执行时机,并可返回清理函数防止内存泄漏。

如何使用usestate和useeffect管理状态? - php中文网

如果您在 React 函数组件中需要管理局部状态并响应生命周期事件,则必须借助 Hook 来实现。以下是使用 useState 和 useEffect 管理状态的具体操作方式:

一、使用 useState 声明和更新状态

useState 是 React 提供的用于在函数组件中添加状态变量的 Hook,它返回一个状态值和一个更新该值的函数。每次调用 setState 都会触发组件重新渲染,并使用新值替换旧值。

1、在组件顶部导入 useState:import { useState } from 'react';

2、声明状态变量,例如声明一个名为 count 的数字状态:const [count, setCount] = useState(0);

3、在 JSX 中显示状态值:{count}

4、通过事件处理函数更新状态,例如点击按钮时递增:setCount(count + 1);

二、使用 useEffect 执行副作用操作

useEffect 用于在函数组件中执行副作用逻辑,如数据获取、订阅或手动 DOM 操作。它接收一个函数作为参数,在组件挂载、更新和卸载时按需执行。

1、在组件顶部导入 useEffect:import { useEffect } from 'react';

2、在组件内部调用 useEffect,传入副作用函数:useEffect(() => { console.log('组件已渲染'); });

3、若仅需在挂载时执行一次,传入空数组作为第二个参数:useEffect(() => { fetchData(); }, []);

4、若需响应某个状态变化而执行,将该状态放入依赖数组:useEffect(() => { document.title = `计数:${count}`; }, [count]);

三、组合 useState 和 useEffect 实现数据加载

常见场景是组件初始化时请求远程数据,并将结果保存到状态中。此时需用 useState 存储数据,用 useEffect 触发请求并更新状态。

汕头吧网上商城系统
汕头吧网上商城系统

特点与优点:1.界面布局合理美观,浏览方便,更具商城站点的风格;2.前后台功能强大好用,如三级分类、竞拍、排行榜、特价、促销、积分等;3.更具人性化,如定单反馈、会员与VIP分别显示不同的售价等;4.优化程序代码,执行速度快速;5.不错的短信联络管理员以及留言本的悄悄话功能等。功能介绍:商品的添加、修改、删除。 管理商品的订单及修改订单状态和网友对商品的评论。管理网站前台用户,可进行修改、删除操作

下载

1、声明数据状态和加载状态:const [data, setData] = useState(null); const [loading, setLoading] = useState(true);

2、在 useEffect 中发起 fetch 请求:useEffect(() => { fetch('/api/items').then(res => res.json()).then(setData).finally(() => setLoading(false)); }, []);

3、在 JSX 中根据 loading 状态渲染不同内容:{loading ? 加载中... :

{data?.map(item =>

{item.name}

)}

}

4、注意避免重复请求:确保依赖数组为空数组([]),且未在每次渲染时创建新的函数或对象传入 useEffect。

四、清理副作用以防止内存泄漏

当 useEffect 中设置了定时器、事件监听器或 WebSocket 连接时,必须在组件卸载前清理它们,否则可能引发内存泄漏或状态更新错误。

1、在 useEffect 的回调函数中返回一个清理函数:useEffect(() => { const timer = setInterval(() => setCount(c => c + 1), 1000); return () => clearInterval(timer); }, []);

2、清理函数会在组件卸载前执行,也可在下一次 effect 运行前执行(当依赖变化时)。

3、确保清理函数中不引用已过期的状态值,必要时使用 useRef 保存最新值。

4、对事件监听器执行 removeEventListener,对订阅执行 unsubscribe,均应在返回的函数中完成。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

435

2024.03.01

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

523

2023.09.20

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

4

2026.01.15

热门下载

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

精品课程

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

共58课时 | 3.6万人学习

国外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号