React useState修改对象

从0开始学react系列

React 中,useState 是一个 Hook,它可以让函数组件拥有状态。当想要改变一个对象类型的状态时,我们需要使用展开运算符(...)或者 Object.assign 来确保状态是正确地更新。

以下是一个使用 useState 来更新对象的例子:

// App.jsx
import React, { useState } from 'react'

function App() {
  const [user, setUser] = useState({ name: '孙悟空', age: 5000 })
 
  function updateUser(newUserData) {
    setUser({ ...user, ...newUserData })
  }
 
  return (
    <div>
      <h1>Name: {user.name}</h1>
      <h1>Age: {user.age}</h1>
      <button onClick={() => updateUser({ name: '菩提老祖' })}>
      	修改名字为菩提老祖
      </button>
    </div>
  )
}
 
export default App

在这个例子中,updateUser 函数接受一个对象 newUserData ,该对象包含了要更新的属性。通过使用展开运算符 ... 来复制当前的 user 状态,并将 newUserData 中的属性加入到新的对象中,然后用 setUser 更新状态。这样可以确保组件状态的正确更新,避免了引用类型的问题。

封面图

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值