VueUse使用及造轮子选择对比示例详解
💬 前言
想想一名React
开发开发Vue
是什么体验。就在今天初含泪写多一个vue
项目,不是转,是写多!选用的是vue3+vite开发。Composition API
让我得心应手。
之前react开发选的是react16,ahooks
是我接触最多的hooks
库了,很贴合我的业务。在使用vue3的时候开发的时候选取了 vueuse
。
👨🏫 问题
在前端开发中和请求打交道是最多的,大多数业务都是restful api架构,我们拿到数据做处理,当前流行的框架配备着状态机制,在依赖变化时进行重新请求等。 vueuse
中的 useFetch
和 useAxios
是作为请求的 hook
。
useFetch功能比较单一,只有请求体的一些基本功能。useAxios
更多基于axios内置功能的封装,业务中的依赖刷新,防抖,节流,缓存等功能都没有的。
这里就有小伙伴问了,那你在 useAxios
上封装这些节流防抖功能就好了,先不说需要侵入式的修改这个钩子,它仅支持axios
,万一项目变成request
呢?
🙋♂️ 解决
ahooks 是前端界大名鼎鼎的 react 的 hooks,它含有更加丰富的功能,能贴合我们更多的业务,其中的 useRequest
是满足我的需求的,但苦于没有vue版本,于是我觉得自己开发一版基于vue3特性的useRequest
。它具备了ahooks的所有功能:
- 自动请求/手动请求
- 轮询
- 防抖
- 节流
- 屏幕聚焦重新请求
- 错误重试
- loading delay
- SWR(stale-while-revalidate)
- 缓存
- 插件式
const { loading: Ref<boolean>, data?: Ref<TData>, error?: Ref<Error>, params: Ref<TParams || []>, run: (...params: TParams) => void, runAsync: (...params: TParams) => Promise<TData>, refresh: () => void, refreshAsync: () => Promise<TData>, mutate: (data?: TData | ((oldData?: TData) => (TData | undefined))) => void, cancel: () => void, } = useRequest<TData, TParams>( service: (...args: TParams) => Promise<TData>, { manual?: boolean, defaultParams?: TParams, onBefore?: (params: TParams) => void, onSuccess?: (data: TData, params: TParams) => void, onError?: (e: Error, params: TParams) => void, onFinally?: (params: TParams, data?: TData, e?: Error) => void, ...高级功能,更多请见文档 } );
这个useRequest
请求体允许传入任意promise对象,所以它并不限制是axios还是request,并且功能都是一致的。
如果想使用请求库的一些特定功能,我们可以封装那些特定功能成为useRequest
的插件,可以控制在它的生命周期中调用。
所以它既体现出包容性又体现出对于单个个体特殊功能的接纳。
插件化的使用
<template> <div>{{ data?.name ?? '-' }}</div> <div>{{ data?.age ?? '-' }}</div> </template> <script lang="ts" setup> import { useRequest } from 'vue-hooks-plus' import { Plugin } from '../../../types' // 插件 const useFormatter: Plugin< { name: string age: number }, [] > = (fetchInstance, { formatter }) => { return { onSuccess: () => { fetchInstance.setData(formatter(fetchInstance.state.data), 'data') }, } } function getUsername(): Promise<{ name: string; age: number }> { return new Promise((resolve, reject) => { setTimeout(() => { resolve({ name: 'yong_git', age: 18, }) }, 1000) }) } const { data } = useRequest( () => getUsername(), { formatter: () => { return { name: 'plugins update', age: 20, } }, }, [useFormatter] ) </script>
上面实现了一个formatter返回结果的插件,它在请求完成的时候return {name: 'plugins update',age: 20,}
覆盖了请求的结果,更多详情请见文档。
下面是我基于ahooks实现的vue的hooks库 vue-hooks-plus
,收获很多,框架的机制所体现出来的独特性让人眼前一亮 🤩。后续还会挑重点hooks详细讲解原理和大家分享。
更多
以上就是VueUse使用及造轮子选择对比示例详解的详细内容,更多关于VueUse对比造轮子的资料请关注脚本之家其它相关文章!
相关文章
Vue自定义表单验证(rule,value,callback)使用详解
这篇文章主要介绍了Vue自定义表单验证(rule,value,callback)使用详解,今天我们讲一讲自定义验证规则具体使用场景和它的三个参数意思和使用,需要的朋友可以参考下2023-07-07vue中展示、读取.md 文件的方法(批量引入、自定义代码块高亮样式)
这篇文章主要介绍了vue中展示、读取.md 文件的方法(批量引入、自定义代码块高亮样式),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-05-05Vue3 Element-plus el-menu无限级菜单组件封装过程
对于element中提供给我们的el-menu组件最多可以实现三层嵌套,如果多一层数据只能自己通过变量去加一层,如果加了两层、三层这种往往是行不通的,所以只能进行封装,这篇文章主要介绍了Vue3 Element-plus el-menu无限级菜单组件封装,需要的朋友可以参考下2023-04-04vue3使用vis绘制甘特图制作timeline可拖动时间轴及时间轴中文化(推荐)
这篇文章主要介绍了vue3使用vis绘制甘特图制作timeline可拖动时间轴,时间轴中文化,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-02-02elementui使用el-upload组件如何实现自定义上传
这篇文章主要介绍了elementui使用el-upload组件如何实现自定义上传,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-08-08
最新评论