React 中 useState 语法详解

1. 语法定义

javascript 复制代码
const [state, dispatch] = useState(initData)

state:定义的数据源,可视作一个函数组件内部的变量,但只在首次渲染被创造。

dispatch:改变state的函数,推动函数渲染的渲染函数,有非函数和函数两种情况。

initData:state的初始值,有非函数和函数两种情况。

2. 使用案例

1. 变量的定义和修改

javascript 复制代码
import { useState } from 'react'

// 定义变量
const [name, setName] = useState('Vue')

// 修改变量
const handleUpdate = () => {
    setName('React')
}

2. 对象的定义和修改

javascript 复制代码
import { useState } from 'react'

// 定义对象
const [user, setUser] = useState({ name: '张三', age: 30 })

// 修改对象
const handleUser = () => {
    // setUser({ name: '李四', age: 50 })
    setUser({ ...user, age: 50 })
}

3. 数组的定义和修改

javascript 复制代码
import { useState } from 'react'

// 定义数组
const [list, setList] = useState(['Tom', 'Jack']);

// 修改数组
const handleList = () => {
    setList([...list, 'Lily'])
}

4. 声明时添加逻辑返回

javascript 复制代码
import { useState } from 'react'

const num = 1;

// 声明通过函数返回
const [name ,setName] = useState(()=>{
    if(num==1){
        return "这是单数"
    }else{
        return "这是双数"
    }
})

5. 更新时添加逻辑返回

javascript 复制代码
import { useState } from 'react'

// 定义变量
const [count, setCount] = useState(0);

// 修改变量
const handleCount = () => {
    // 通过函数返回
    setCount((count) => count + 1)

}

3. 异步更新

React是异步更新,它会将多次更新合并到一起。

javascript 复制代码
import { useState } from 'react'

// 定义变量
const [count, setCount] = useState(0);

// 修改变量
const handleCount = () => {
    setCount(count => count + 1)
    setCount(count => count + 1)
    setCount(count => count + 1)
    setCount(count => count + 1)
}

由于React是异步合并更新,上面调用了4次setCount会统一合并,值会变为4,但只会渲染一次。

如果想要强制刷新渲染,可以使用flushSync函数提高优级,这样就会又渲染一次。

javascript 复制代码
import { useState } from 'react'

import { flushSync } from 'react-dom'


// 定义变量
const [count, setCount] = useState(0);

// 修改变量
const handleCount = () => {

    // setCount(count => count + 1)
    // setCount(count => count + 1)
    // setCount(count => count + 1)
    // setCount(count => count + 1)

    // 合并批量更新渲染一次
    setTimeout(() => {
        setCount(count => count + 1)
        setCount(count => count + 1)
        setCount(count => count + 1)
        setCount(count => count + 1)
    })
    // 强制更新渲染一次
    flushSync(() => {
        setCount(count => count + 1)
        setCount(count => count + 1)
    })

}
相关推荐
流年染指悲伤、13 小时前
2024年最新技术趋势分析:AI、前端与后端开发新动向
人工智能·前端开发·后端开发·2024·技术趋势
千码君20164 天前
React Native:发现默认参数children【特殊的prop】
javascript·react native·ecmascript·react·组件树
aiguangyuan6 天前
微信小程序中的双线程模型及数据传输优化
微信小程序·前端开发
前端OnTheRun10 天前
React18学习笔记(四) 路由案例--记账本
react·router
whltaoin12 天前
Vue 与 React 深度对比:技术差异、选型建议与未来趋势
前端·前端框架·vue·react·技术选型
知识分享小能手13 天前
微信小程序入门学习教程,从入门到精通,微信小程序常用API(下)——知识点详解 + 案例实战(5)
前端·javascript·学习·微信小程序·小程序·vue·前端开发
PyAIGCMaster17 天前
我的项目开发的一般流程,供交流
react·nextjs
aesthetician18 天前
ReactFlow:构建交互式节点流程图的完全指南
前端·流程图·react
fcm1919 天前
(6) tauri之前端框架性能对比
前端·javascript·rust·前端框架·vue·react
知识分享小能手20 天前
React学习教程,从入门到精通,React 前后端交互技术详解(29)
前端·javascript·vue.js·学习·react.js·前端框架·react