React学习(二),2025/5/10,笔记记录

1、useReducer()的使用,(和useState一样用于状态管理)

js 复制代码
import { useReducer } from "react";

function reducer (state, action){
  switch(action.type){
    case 'INC':
      return state + 1
    case 'DEC':
      return state - 1
    case 'SET':
      return action.payload  
    default:
      return state
  }
}

function App() {
  const [state, dispatch] = useReducer(reducer, 0)
  return (
    <div className="App">
      <button onClick={() => dispatch({ type: 'INC' })}>+++</button>
      ------{state}
      <button onClick={() => dispatch({ type: 'DEC' })}>---</button>
      <button onClick={() => dispatch({ type: 'SET',payload: 100 })}>updata</button>
    </div>
  );
}

export default App;

2、useMemo在组件每次重新渲染时缓存计算的结果,类似useEffect

因为useState状态在调用改变时,会使得整个组件进行重新渲染

js 复制代码
    useMemo(() => {
        //根据count1返回计算结果,只有count1依赖项发生变化时才重新计算
    }, [count1])

3、React.memo基本使用,(防止子组件重复渲染)

  • useState状态在调用改变时,会使得整个组件进行重新渲染
  • props(属性)是父组件传递给子组件的数据。
  • context 是 React 提供的一种跨组件层级传递数据的机制,不需要显式地通过 props 逐层传递。
js 复制代码
import { memo, useState } from "react" 

const MemoSon = memo(function Son () {
  console.log('我是子组件,我重新渲染了')
  return <div>this is son</div>
}) 

function App () {
  const [count, setCount] = useState(0)
  return (
    <div className="App">
      <button onClick={() => setCount(count + 1)}>+{count}</button> 
      <MemoSon />
    </div>
  )
}

export default App

4、React.memo的props比较机制,当发送变化时返回false

js 复制代码
// React.memo props比较机制

// 1. 传递一个简单类型的prop   prop变化时组件重新渲染

// 2. 传递一个引用类型的prop   比较的是新值和旧值的引用是否相等  当父组件的函数重新执行时,实际上形成的是新的数组引用

// 3. 保证引用稳定 -> useMemo 组件渲染的过程中缓存一个值

import { memo, useMemo, useState } from 'react'

const MemoSon = memo(function Son({ list }) {
  console.log('子组件重新渲染了')
  return <div>this is Son {list}</div>
})


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

  // const num = 100

  const list = useMemo(() => {
    return [1, 2, 3]
  }, [])

  return (
    <div className="App">
      <MemoSon list={list} />
      <button onClick={() => setCount(count + 1)}>change Count</button>
    </div>
  )
}

export default App

5、useCallback缓存函数,防止子组件多次渲染(类似useMemo)

js 复制代码
// useCallback

import { memo, useCallback, useState } from "react"


const Input = memo(function Input ({ onChange }) {
  console.log('子组件重新渲染了')
  return <input type="text" onChange={(e) => onChange(e.target.value)} />
})

function App () {
  // 传给子组件的函数
  const changeHandler = useCallback((value) => console.log(value), [])
  // 触发父组件重新渲染的函数
  const [count, setCount] = useState(0)
  return (
    <div className="App">
      {/* 把函数作为prop传给子组件 */}
      <Input onChange={changeHandler} />
      <button onClick={() => setCount(count + 1)}>{count}</button>
    </div>
  )
}

export default App

6、forwardRef在父组件控制子组件的元素

js 复制代码
import { forwardRef, useRef } from "react"

// 子组件
// function Son () {
//   return <input type="text" />
// }

const Son = forwardRef((props, ref) => {
  return <input type="text" ref={ref} />
})


// 父组件
function App() {
  const sonRef = useRef(null)
  const showRef = () => {
    console.log(sonRef)
    sonRef.current.focus()
  }
  return (
    <>
      <Son ref={sonRef} />
      <button onClick={showRef}>focus</button>
    </>
  )
}

export default App

7、useImperativeHandle暴露子元素中的方法

js 复制代码
import { forwardRef, useImperativeHandle, useRef } from "react"

// 子组件

const Son = forwardRef((props, ref) => {
  // 实现聚焦逻辑
  const inputRef = useRef(null)
  const focusHandler = () => {
    inputRef.current.focus()
  }

  // 把聚焦方法暴露出去
  useImperativeHandle(ref, () => {
    return {
      // 暴露的方法
      focusHandler
    }
  })
  return <input type="text" ref={inputRef} />
})


// 父组件
function App () {
  const sonRef = useRef(null)
  const focusHandler = () => {
    console.log(sonRef.current)
    sonRef.current.focusHandler()
  }
  return (
    <>
      <Son ref={sonRef} />
      <button onClick={focusHandler}>focus</button>
    </>
  )
}

export default App

8、class类组件基础结构

只是编写组件的一种方式,了解即可

9、zustand状态管理工具

zustand (React) | ZUSTAND文档

10、vite创建react-ts项目

npm create vite@latest my-react-ts-app -- --template react-ts

11、ts泛型,useState可以自动推断初始值,useState传递泛型函数

<user | null> 可以设置初始值为null

12、props和ts的联合使用

相关推荐
LaiYoung_几秒前
深入解析 single-spa 微前端框架核心原理
前端·javascript·面试
Danny_FD1 小时前
Vue2 + Node.js 快速实现带心跳检测与自动重连的 WebSocket 案例
前端
uhakadotcom1 小时前
将next.js的分享到twitter.com之中时,如何更新分享卡片上的图片?
前端·javascript·面试
韦小勇1 小时前
el-table 父子数据层级嵌套表格
前端
奔赴_向往1 小时前
为什么 PWA 至今没能「掘进」主流?
前端
小小愿望1 小时前
微信小程序开发实战:图片转 Base64 全解析
前端·微信小程序
掘金安东尼1 小时前
2分钟创建一个“不依赖任何外部库”的粒子动画背景
前端·面试·canvas
电商API大数据接口开发Cris1 小时前
基于 Flink 的淘宝实时数据管道设计:商品详情流式处理与异构存储
前端·数据挖掘·api
小小愿望1 小时前
解锁前端新技能:让JavaScript与CSS变量共舞
前端·javascript·css
程序员鱼皮1 小时前
爆肝2月,我的 AI 代码生成平台上线了!
java·前端·编程·软件开发·项目