React学习-hooks

官方文档:https://zh-hans.react.dev/reference/react/useActionState

1.useEffect(setup, dependencies?)

1.1 基础使用

js 复制代码
//hooks
import { useEffect } from "react";
import "./App.css";

function App(){

  useEffect(()=>{
    console.log('useEffect loading');
  })

  return ( <h1>app</h1>)
}

export default App;

执行时机:

1,组件初始化

2,组件更新后执行(在dom更新之后执行)

1.2 传入依赖项时 []

js 复制代码
  //第一个参数回调函数,组件初始化执行,组件更新后也会执行
  useEffect(()=>{
    console.log('useEffect loading');
  },[])

执行时机:

组件初始化、挂载

1.3 传入依赖项时 [a]

useEffect可以监听到useState的状态变化

(如果依赖项中传入多个值[a,b,c],只有有其中之一变化都会执行useEffect。或的关系)

js 复制代码
import { useEffect, useState } from "react";
import "./App.css";

function App() {
  const [count, setCount] = useState(0);

  //第一个参数回调函数,组件初始化执行,组件更新后也会执行
  useEffect(() => {
    console.log("useEffect loading");
    console.log(count);

    // return () => {
    //   console.log('return 的函数在卸载的时候执行');
    // }
  }, [count]);

  const btn = () => {
    setCount(count + 1);
  };

  return (
    <div>
      <h1>hooks</h1>
      <h1>{count}</h1>
      <button onClick={btn}>add</button>
    </div>
  );
}

export default App;

执行时机:

1,组件初始化、挂载

2,依赖项的状态变化时

1.4 第二个参数不传

第二个参数不传,会将所有定义的state值收集起来,只有有一个值变化了就会执行useEffect

1.5 返回的函数 ☆

执行时机:

1,组件卸载的时候

2,状态发生变化时

js 复制代码
  useEffect(() => {
    console.log("useEffect loading",count);//变化后的数据
    
    return(()=>{//return 中的值是变化之前的数据
      console.log('return!!',count);
    })
  });

应用场景:用于聊天的卸载

用户我跟多个人聊天的场景:

伪代码:

跟用户A

js 复制代码
function Bpp(){

  useEffect(() => {
	//userA
	connect(userA)
	
    return(()=>{
      console.log('return!!');
    })
    
  },[userA]);
}

离开A页面,到用户B

js 复制代码
function Bpp(){

  useEffect(() => {
	//userB
	connect(userB)
	
    return(()=>{
    	//userA
      console.log('return!!');
      //断开A的连接
      disconnect(userA)
    })
    
  },[userB]);//A-->B
}

2.useState

const [state, setState] = useState(initialState)

js 复制代码
import {  useState } from "react";
import "./App.css";

function App() {
  const [count, setCount] = useState(0)
  
  const btn=()=>{
    setCount(count+1)
  }

  return ( 
  <div>
    <h1>hooks</h1>
    <h1>{count}</h1>
    <button onClick={btn} >add</button>
  </div>
  )
}
export default App;

面试题

react的更新是同步还是异步的?为什么?

异步,因为react更新底层的(微任务)异步队列,会将短时间内js对组件的更新合并,1次渲染完成更新。

useEffect的执行时机?

看第一点

useEffect的返回函数执行时机

1,组件卸载的时候

2,状态发生变化时

应用场景:用于聊天的卸载

相关推荐
·中年程序渣·2 分钟前
Spring AI Alibaba入门学习(五)
人工智能·学习
软弹4 分钟前
Vue2、Vue3、React 状态管理全方位对比
前端·javascript·vue.js·react.js
BYWled8 分钟前
告别 Date | JavaScript Temporal API 使用教程
javascript
AnalogElectronic39 分钟前
RP2040学习4,LED点亮,OLED显示,DHT11温湿度传感器数据读取
单片机·嵌入式硬件·学习
酉鬼女又兒41 分钟前
HTML基础实例样式详解零基础快速入门Web开发(可备赛蓝桥杯Web应用开发赛道) 助力快速拿奖
前端·javascript·职场和发展·蓝桥杯·html·html5·web
adore.96844 分钟前
3.15 复试学习
学习
Watermelo6171 小时前
【前端实战】构建 Vue 全局错误处理体系,实现业务与错误的清晰解耦
前端·javascript·vue.js·信息可视化·性能优化·前端框架·设计规范
不光头强1 小时前
jwt学习
java·大数据·学习
952361 小时前
MySQL - 集群架构与实践
数据库·学习·mysql·架构
进击的尘埃1 小时前
Vue 3 编译器宏的编译时魔法:defineModel、defineSlots 与 AST 转换的真相
javascript