React useState 和 useEffect 使用坑点注意总结

React Hooks 使用注意事项

Area: Hooks
Date: February 10, 2025
Important: 🌟🌟🌟

React Hooks 注意事项

要点:

  • useState 的初始化值 只在第一次渲染时计算,并且这个值不会随着组件重新渲染而更新。
  • useEffect 可能出现死循环,比如处理请求接口时,依赖项绑定对象类型数据,会死循环。


useState 的初始值问题

Case:useState 的初始化值 只在第一次渲染时计算,并且这个值不会随着组件重新渲染时更新。

理解:useState 的初始化值只在组件的第一次渲染时生效,不会随着 propsstate 的变化而更新。

2025-02-16 23.03.54.gif

import React, {
    useState } from 'react'

// 子组件
function Child({
     userInfo }) {
   
  // render: 初始化 state
  // re-render: 只恢复初始化的 state 值,不会再重新设置新的值
  //            只能用 setName 修改
  const [name, setName] = useState(userInfo.name)

  return (
    <div>
      <p>Child, props name: {
   userInfo.name}</p>
      <p>Child, state name: {
   name}</p>
    </div>
  )
}

function App() {
   
  const [name, setName] = useState('双越')
  const userInfo = {
    name }

  return (
    <div>
      <div>
        Parent &nbsp;
        <button onClick={
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值