一、useState的作用
- 在函数组件中的
this指向
在react中是undefined
,使用useState可以使组件state状态
, 并进行状态数据的读写操作- 作用:给函数组件提供数据
- 语法:
const [xxx, setXxx] = React.useState(initValue)
- useState()说明: - 参数(initValue): 第一次初始化
指定的值
在内部作缓存- 返回值([xxx, setXxx]): 包含2个元素的数组
, 第1个为内部当前状态值
, 第2个为更新状态值的函数
- setXxx()2种写法: - setXxx(newValue): 参数为非函数值,
直接指定新的状态值
, 内部用其覆盖原来的状态值- setXxx(value => newValue): 参数为函数
, 接收原本的状态值, 返回新的状态值, 内部用其覆盖原来的状态值
二、useState的使用
1. 定义组件变量
// useState给当前的组件提供数据 相当于class组件 this.state={}import React,{useState}from'react'// 一、 定义组件变量// 参数一: 定义的变量 参数二:定义修改变量的方法 useState(0):初始值,相当于num=10const[count, setState]=useState(0)const[name, setName]=useState('tome')
2. 使用变量{变量名称}
{/* 二、使用变量{变量名称} */}
<h2>当前求和为:{count}</h2><buttononClick={add}>点我+1</button><br/><h2>我的名字是:{name}</h2><buttononClick={changeName}>点我改名</button>
3. 函数修改state数据 合并操作,执行最后一次
// 三、函数修改state数据 合并操作,执行最后一次functionadd(){// setState(count+1) //第一种写法: 对值直接操作setState(count=> count+1)//第二种写法:回调函数}constchangeName=()=>{// 定义变量--定义修改的方法setName('jack')}
4. 合并操作 执行最后一次
//宏任务 直接渲染4setTimeout(()=>{setState(count+4)},0)//微任务 直接打印 5
Promise.resolve().then(res=>{setState(count +5)})
三、案例分析
1. 类组件的方法
import React,{ Component }from'react'exportdefaultclassDemoextendsComponent{
state ={count:1}add=()=>{this.setState(state=>({count:state.count+1}))}render(){return(<div><h1>当前求和为:{this.state.count}</h1><button onClick={this.add}>点我+1</button></div>)}}
3. 函数组件的方法
import React,{ useState }from'react'// useState给当前的组件提供数据 相当于class组件 this.state={}exportdefaultfunctionDemo(){// 一、 定义组件变量// 参数一: 定义的变量 参数二:定义修改变量的方法 useState(0):初始值,相当于num=10const[count, setState]=useState(0)const[name, setName]=useState('tome')// 三、函数修改state数据 合并操作,执行最后一次functionadd(){// setState(count+1) //第一种写法: 对值直接操作setState(count=> count +1)//第二种写法:回调函数// //宏任务 直接渲染4// setTimeout(()=>{// setState(count+4)// },0)// //微任务 直接打印 5// Promise.resolve().then(res => {// setState(count + 5)// })}constchangeName=()=>{// 定义变量--定义修改的方法setName('jack')}return(<div>{/* 二、使用变量{变量名称} */}<h2>当前求和为:{count}</h2><button onClick={add}>点我+1</button><br /><h2>我的名字是:{name}</h2><button onClick={changeName}>点我改名</button></div>)}
本文转载自: https://blog.csdn.net/m0_58190023/article/details/128943765
版权归原作者 0yizhiyang 所有, 如有侵权,请联系我们删除。
版权归原作者 0yizhiyang 所有, 如有侵权,请联系我们删除。