0


useState的理解和使用

一、useState的作用


  1. 在函数组件中的this指向在react中是undefined,使用useState可以使组件state状态, 并进行状态数据的读写操作
  2. 作用:给函数组件提供数据
  3. 语法:const [xxx, setXxx] = React.useState(initValue)
  4. useState()说明: - 参数(initValue): 第一次初始化指定的值在内部作缓存- 返回值([xxx, setXxx]): 包含2个元素的数组, 第1个为内部当前状态值, 第2个为更新状态值的函数
  5. 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 所有, 如有侵权,请联系我们删除。

“useState的理解和使用”的评论:

还没有评论