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,状态发生变化时

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

相关推荐
YAy1735 分钟前
CC3学习记录
java·开发语言·学习·网络安全·安全威胁分析
谁呛我名字2 小时前
大数据应用开发——数据可视化
javascript·vue.js·echarts
前端郭德纲2 小时前
浅谈React的虚拟DOM
前端·javascript·react.js
懒惰的cv怪2 小时前
Redis学习 ——缓存
redis·学习·缓存
心怀梦想的咸鱼3 小时前
UE5 umg学习(四) 将UI控件显示到关卡中
学习·ui·ue5
ComPDFKit4 小时前
使用 PDF API 合并 PDF 文件
前端·javascript·macos
yqcoder4 小时前
react 中 memo 模块作用
前端·javascript·react.js
谈谈叭4 小时前
Javascript中的深浅拷贝以及实现方法
开发语言·javascript·ecmascript
lx学习4 小时前
Python学习26天
开发语言·python·学习
优雅永不过时·5 小时前
Three.js 原生 实现 react-three-fiber drei 的 磨砂反射的效果
前端·javascript·react.js·webgl·threejs·three