【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
相关推荐
豐儀麟阁贵几秒前
8.5在方法中抛出异常
java·开发语言·前端·算法
zengyuhan50330 分钟前
Windows BLE 开发指南(Rust windows-rs)
前端·rust
醉方休33 分钟前
Webpack loader 的执行机制
前端·webpack·rust
前端老宋Running42 分钟前
一次从“卡顿地狱”到“丝般顺滑”的 React 搜索优化实战
前端·react.js·掘金日报
隔壁的大叔42 分钟前
如何自己构建一个Markdown增量渲染器
前端·javascript
用户44455436542644 分钟前
Android的自定义View
前端
WILLF1 小时前
HTML iframe 标签
前端·javascript
枫,为落叶1 小时前
Axios使用教程(一)
前端
小章鱼学前端1 小时前
2025 年最新 Fabric.js 实战:一个完整可上线的图片选区标注组件(含全部源码).
前端·vue.js
ohyeah1 小时前
JavaScript 词法作用域、作用域链与闭包:从代码看机制
前端·javascript