react 常用的hooks—useState、useEffect

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

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 --> 返回函数(即将更新) --> 完成更新(副作用函数)
  • 卸载阶段:返回函数(即将卸载)
useStateReact Hooks提供的一个函数,用于在函数式组件中声明和使用状态。它接受一个初始值作为参数,并返回一个包含当前状态和更新状态的数组。useState的作用类似于类组件中的this.state和this.setState方法,但是在函数式组件中使用更加简洁方便。 useEffect也是React Hooks提供的一个函数,用于在函数式组件中执行副作用操作,比如订阅事件、发送网络请求、操作DOM等。它接受两个参数,第一个参数是一个回调函数,用于执行副作用操作,第二个参数是一个依赖数组,用于指定何时重新执行副作用操作。useEffect的作用类似于类组件中的生命周期方法,比如componentDidMount、componentDidUpdate和componentWillUnmount。 useCallback也是React Hooks提供的一个函数,用于在函数式组件中缓存回调函数。它接受一个回调函数和一个依赖数组作为参数,并返回一个经过缓存的回调函数。useCallback的作用是在依赖数组不变的情况下,避免不必要的函数重新创建,提高性能。 综上所述,useState用于声明和使用状态,useEffect用于执行副作用操作,而useCallback用于缓存回调函数。它们都是React Hooks提供的函数,可以在函数式组件中方便地使用。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [搞懂React Hooks之 useState, useCallback, useEffect, useRef ,useMemo和useEffect](https://blog.csdn.net/qq_27401917/article/details/116699141)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [学习记录431@reactuseStateuseEffectuseCallback](https://blog.csdn.net/weixin_44663675/article/details/119121498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值