【REACT18.x】CRA+TS+ANTD5.X封装自定义的hooks复用业务功能

模拟react中的hooks方法,实现自定义的hooks来封装我们需要重复使用的组件,来优化代码。这种hooks也是利用了react的原生hooks来实现我们需要的特定业务,可以返回任何我们需要的值,也可以不返回值,作为一个副作用方法使用

第三方hooks

下面,封装了几个自己的简单hooks,加深下对hooks的理解

修改页面标题

  • 实现效果

  • 实现代码

js 复制代码
import { useEffect } from 'react'

export function useTitle(title: string): void {
    useEffect(() => {
        document.title = title
    }, [])
}

捕获鼠标位置

  • 实现效果
  • 实现代码
js 复制代码
import { useCallback, useEffect } from 'react'
import { useImmer } from 'use-immer'

type TPosition = {
    x: number
    y: number
}

function useMouse(): TPosition {
    const [position, setPosition] = useImmer<TPosition>({
        x: 0,
        y: 0
    })
    const updateMouse = useCallback((e: MouseEvent) => {
        console.log('useEffect updateMouse')
        setPosition(draft => {
            draft.x = e.clientX
            draft.y = e.clientY
        })
    }, [])

    useEffect(() => {
        document.addEventListener('mousemove', updateMouse)

        return () => {
            document.removeEventListener('mousemove', updateMouse)
        }
    })

    return position
}

export default useMouse

异步请求

  • 实现效果
  • 实现代码
js 复制代码
import { useEffect } from 'react'
import { useImmer } from 'use-immer'

type TResult = {
    name: string
    age: number
}
function getInfo(): Promise<TResult> {
    return new Promise(resolve => {
        setTimeout(() => {
            resolve({
                name: 'why',
                age: 18
            })
        }, 2000)
    })
}

const useGetInfo = () => {
    const [loading, setLoading] = useImmer(false)
    const [info, setInfo] = useImmer<TResult | null>(null)

    useEffect(() => {
        setLoading(true)
        getInfo().then(result => {
            setInfo(result)
            setLoading(false)
        })
    }, [])

    return { loading, info }
}

export default useGetInfo
相关推荐
ZC跨境爬虫4 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
前端老石人4 小时前
HTML 字符引用完全指南
开发语言·前端·html
幼儿园技术家5 小时前
前端如何设计权限系统(RBAC / ABAC)?
前端
前端摸鱼匠6 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker7 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
donecoding8 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马8 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren8 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川8 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端