【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
相关推荐
天一生水water4 分钟前
three.js加载三维GLB文件,查看三维模型
前端·1024程序员节
无风听海8 分钟前
HarmonyOS之启动应用内的UIAbility组件
前端·华为·harmonyos
冰夏之夜影18 分钟前
【科普】Edge出问题后如何恢复出厂设置
前端·edge
葱头的故事1 小时前
vant van-uploader上传file文件;回显时使用imageId拼接路径
前端·1024程序员节
Mintopia2 小时前
🇨🇳 Next.js 在国内场景下的使用分析与实践指南
前端·后端·全栈
Mintopia2 小时前
深度伪造检测技术在 WebAIGC 场景中的应用现状
前端·javascript·aigc
BUG_Jia2 小时前
如何用 HTML 生成 PC 端软件
前端·javascript·html·桌面应用·1024程序员节
木易 士心2 小时前
CSS 样式用法大全
前端·css·1024程序员节
皓月Code2 小时前
第二章、全局配置项目主题色(主题切换+跟随系统)
javascript·css·react.js·1024程序员节
012925202 小时前
1.1 笔记 html 基础 初认识
前端·笔记·html