vue3 Hooks 封装loading使用

vue3 Hooks 封装loading使用

个人理解:Hooks 就是 钩子 的意思,在特定时机执行的函数

之前不理解Hooks和自定义封装的utils函数有什么区别,它们都是函数,逐步理解到utils函数没有vue里面的响应式api,而自定义Hooks可以使用响应式api,比如:ref、reactive、onMounted等等

举例说明:

loading大家都不陌生,在项目请求接口时需要显示loading加载提示用户正在请求中的操作,在加载完成隐藏loading,显示返回的数据。

下面使用vue3 Hooks 来封装这个业务场景
定义 Hooks 有一个潜规则,就是要 use 开头

bash 复制代码
// useLoading.ts
import { ref } from 'vue'
export const useLoading = () => {
    const loading = ref(false)
    const show = () => {
        loading.value = true
    }
    const hide = () => {
        loading.value = false
    }
    
    return {
        loading,
        hide,
        show
    }
}

我这里用的elementui框架,使用v-loading绑定loading变量

bash 复制代码
<template>
    <div style="width: 300px;height: 300px;border: 1px solid #000" v-loading="loading">  </div>

    <el-button @click="show">显示loading</el-button>
    <el-button @click="hide">隐藏loading</el-button>
</template>

<script lang="ts" setup>
 import { useLoading } from '@/hooks/useLoading.ts'
 const { 
	loading,
	hide,
	show
	} = useLoading()
</script>

使用Hooks是为了让项目整体的开发代码质量更加高,开发功能更加便捷,效率更高

相关推荐
灿灿121383 小时前
Vue 项目路由模式全解析:从 hash 到 history 再到 abstract
javascript·vue.js·哈希算法
BillKu3 小时前
Vue3 + Element Plus中el-table加载状态分析
javascript·vue.js·elementui
大明883 小时前
滚动锁定技术解析:以Ant Design的useScrollLocker为例
前端·vue.js·前端框架
吃肉不吃皮4 小时前
【Vue转React】更新机制对比,React开发中的心智负担从何而来?
前端·vue.js·react.js
黑土豆4 小时前
使用Web Worker异步解析Word文档:基于Vue 3和Mammoth.js的完整实现
前端·javascript·vue.js
五月仲夏5 小时前
vue中的h渲染函数
前端·javascript·vue.js
wh_xia_jun5 小时前
4步使用 vue3 路由
前端·javascript·vue.js
江城开朗的豌豆5 小时前
Vue为什么要用虚拟DOM?直接操作真实DOM不香吗?
前端·javascript·vue.js
萌萌哒草头将军5 小时前
🚀🚀🚀恭喜 Rolldown 获得 JS 开源奖年度突破奖,2025 年 JS 开源奖典礼回顾!🎉🎉🎉
前端·vue.js·react.js
江城开朗的豌豆5 小时前
nextTick vs setTimeout:Vue中的'马上'和'等会儿'到底差在哪?
前端·javascript·vue.js