React 中 useState 语法详解

打印 上一主题 下一主题

主题 985|帖子 985|积分 2955

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
 1. 语法界说

  1. const [state, dispatch] = useState(initData)
复制代码
state:界说的数据源,可视作一个函数组件内部的变量,但只在首次渲染被创造。
dispatch:改变state的函数,推动函数渲染的渲染函数,有非函数和函数两种情况。
initData:state的初始值,有非函数和函数两种情况。

2. 使用案例

1. 变量的界说和修改

  1. import { useState } from 'react'
  2. // 定义变量
  3. const [name, setName] = useState('Vue')
  4. // 修改变量
  5. const handleUpdate = () => {
  6.     setName('React')
  7. }
复制代码
2. 对象的界说和修改

  1. import { useState } from 'react'
  2. // 定义对象
  3. const [user, setUser] = useState({ name: '张三', age: 30 })
  4. // 修改对象
  5. const handleUser = () => {
  6.     // setUser({ name: '李四', age: 50 })
  7.     setUser({ ...user, age: 50 })
  8. }
复制代码
3. 数组的界说和修改

  1. import { useState } from 'react'
  2. // 定义数组
  3. const [list, setList] = useState(['Tom', 'Jack']);
  4. // 修改数组
  5. const handleList = () => {
  6.     setList([...list, 'Lily'])
  7. }
复制代码
4. 声明时添加逻辑返回

  1. import { useState } from 'react'
  2. const num = 1;
  3. // 声明通过函数返回
  4. const [name ,setName] = useState(()=>{
  5.     if(num==1){
  6.         return "这是单数"
  7.     }else{
  8.         return "这是双数"
  9.     }
  10. })
复制代码
5. 更新时添加逻辑返回

  1. import { useState } from 'react'
  2. // 定义变量
  3. const [count, setCount] = useState(0);
  4. // 修改变量
  5. const handleCount = () => {
  6.     // 通过函数返回
  7.     setCount((count) => count + 1)
  8. }
复制代码

3. 异步更新

React是异步更新,它会将多次更新归并到一起。
  1. import { useState } from 'react'
  2. // 定义变量
  3. const [count, setCount] = useState(0);
  4. // 修改变量
  5. const handleCount = () => {
  6.     setCount(count => count + 1)
  7.     setCount(count => count + 1)
  8.     setCount(count => count + 1)
  9.     setCount(count => count + 1)
  10. }
复制代码
由于React是异步归并更新,上面调用了4次setCount会同一归并,值会变为4,但只会渲染一次。
如果想要逼迫刷新渲染,可以使用flushSync函数进步优级,这样就会又渲染一次。
  1. import { useState } from 'react'
  2. import { flushSync } from 'react-dom'
  3. // 定义变量
  4. const [count, setCount] = useState(0);
  5. // 修改变量
  6. const handleCount = () => {
  7.     // setCount(count => count + 1)
  8.     // setCount(count => count + 1)
  9.     // setCount(count => count + 1)
  10.     // setCount(count => count + 1)
  11.     // 合并批量更新渲染一次
  12.     setTimeout(() => {
  13.         setCount(count => count + 1)
  14.         setCount(count => count + 1)
  15.         setCount(count => count + 1)
  16.         setCount(count => count + 1)
  17.     })
  18.     // 强制更新渲染一次
  19.     flushSync(() => {
  20.         setCount(count => count + 1)
  21.         setCount(count => count + 1)
  22.     })
  23. }
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

千千梦丶琪

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表