react 常用的hooks—useState、useEffect

本文详细介绍了React中的函数式组件和Hooks,特别是useState和useEffect的用法。函数组件没有state和生命周期,但通过useState可以添加状态管理,并且注意useState的setState不会合并对象。同时,useEffect用于处理副作用,根据依赖参数决定何时执行。文章还展示了如何在组件中使用这些Hooks以及它们的执行顺序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

React组件:可以分为类组件和函数式组件

1、函数式组件中没有state
2、函数式组件中没有生命周期(重点,涉及到生命周期的方法只能在类组建中定义)
可以借助react提供的hooks在函数式组建中做状态和方法
react对象有个useState函数,可以通过该函数创建状态,并且该函数是有返回值的:

useState

let [状态,修改该状态的方法] = useState(初始值);

const [count,setCount] = useState(0); 
console.log(useState(0)) //[0, ƒ]
  1. 在同一个组件中可以使用 useState 定义多个状态
  2. 注意 useState 返回的 setState 方法,不会进行对象合并
  3. 注意 useState 返回的 setState 方法同样是异步方法
// hooks只能用在组件函数中的最顶层
import { useState } from "react";

function App() {
    // let [count,setCount] = useState(1);
    let [state, setState] = useState({
      count: 1
    });
    let { count } = state;
    const fn = () => {setState({count: count + 1})}
    return (
    <div>
      <p>{count}</p>
      {/* 第一种写法 */}
      {/* <button onClick={() => {
        setState({
          count: count + 1
        })
      }}>递增</button> */}

        {/* 第二种写法 */}
       <button onClick={fn}>递增</button>
      
    </div>
    )
  }
  
export default App  

函数组建的构成一般也是结构,分为三个部分:
1、state部分;2、操作状态的方法;3、return结构(如上面代码注释所示)
无论一个函数组件多么复杂都应该遵循这个解构来创建。

特别注意:使用useState 返回的 setState 方法,不会进行对象合并

// hooks只能用在组件函数中的最顶层
import { useState } from "react";

function App() {
  let [state, setState] = useState({
    name: "xiaochen",
    count: 1,
  });
  let { name, count } = state;
  console.log("render");
  return (
    <div>
      <input
        type="text"
        value={name}
        onChange={({ target }) => {
          setState({
            ...state, //由于不会进行对象合并
            name: target.value,
          });
        }}
      />
      <p>{name}</p>
      <p>{count}</p>
      <button
        onClick={() => {
          setState({
            ...state, //由于不会进行对象合并
            count: count + 1,
          });
          console.log("修改");
        }}
      >
        递增
      </button>
    </div>
  );
}

export default App;

useEffect

useEffect 用法 页面加载 就渲染此方法 跟vue的created 的道理 还可以做信息依赖

useEffect(()=>{
  //副作用函数
  return ()=>{
    // 副作用函数的返还函数
  }
},[依赖参数])
  • 依赖参数:
  • 当不写依赖参数时,只要组件更新就会执行副作用函数;
  • 当依赖参数为[ ]时,副作用函数只在挂载完之后执行;
  • 写依赖参数,当监听参数修改时,或组件挂载时执行副作用函数。
useEffect(()=>{
   console.log('组件挂载时、count修改时就会执行执行');
 },[count]);
useEffect(()=>{
    console.log("挂载完成之后执行")
},[]);
useEffect(()=>{
    console.log("组件更新就会执行")
});
  • 执行顺序:
  • 挂载阶段: render --> 副作用函数
  • 更新阶段: render --> 返回函数(即将更新) --> 完成更新(副作用函数)
  • 卸载阶段:返回函数(即将卸载)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值