触发事件,按钮loading状态,封装hooks

背景:

正常请求接口中,当接口触发,需要声明loading值,作为监听正在请求或请求完成的状态,此hooks方便了这一写法

TypeScript 复制代码
//uselock.ts

import { ref } from 'vue';

export function useLockFn<T>(fn: (...args: any[]) => Promise<T>) {
  const isLock = ref(false);
  const lockFn = async (...args: any[]): Promise<T | undefined> => {
    if (isLock.value) return;
    isLock.value = true;
    try {
      const res = await fn(...args);
      isLock.value = false;
      return res;
    } catch (error) {
      isLock.value = false;
      throw error;
    }
  };
  return {
    isLock,
    lockFn,
  };
}

如何使用:

isLock是监听开始请求接口为true,请求结束的loading状态为false,

调用事件loginLock触发事件

html 复制代码
<script lang="ts" setup>
import {useLockFn} from './useLockFn.ts'
const { lockFn: loginLock, isLock } = useLockFn(async () => {
  if (phoneStatusType.value !== 'login') {
    ElMessage.warning('该账号未注册,请前往注册!');
    return;
  }
  await formRef.value?.validate();
  await props.submitValid?.();
  await getPhoneStatus();
  // 登录
  const data = Object.assign(formData, {
    username: formData.phonenumber,
    type: phoneStatusType.value,
    loginStatus: false,
  });
  await (formData.scene === LoginWayEnum.CODE
    ? authStore.mobileLogin(data)
    : authStore.adminLogin(data));
  ElMessage.success('登录成功');
});
</script>

<template>
  <el-button :loading="isLock" @click="loginLock">
    触发方法
  </el-button>
</template>
相关推荐
前端伪大叔10 分钟前
freqtrade智能挂单策略,让你的资金利用率提升 50%+
前端·javascript·后端
江城开朗的豌豆11 分钟前
从“any”战士到类型高手:我的TypeScript进阶心得
前端·javascript·前端框架
红尘散仙31 分钟前
TRNovel王者归来:让小说阅读"声"临其境的终端神器
前端·rust·ui kit
知花实央l36 分钟前
【Web应用安全】SQLmap实战DVWA SQL注入(从环境搭建到爆库,完整步骤+命令解读)
前端·经验分享·sql·学习·安全·1024程序员节
烛阴39 分钟前
为你的Lua代码穿上盔甲:精通错误处理的艺术
前端·lua
专注前端30年1 小时前
Vue CLI与Webpack:区别解析与实战使用指南
前端·vue.js·webpack
余道各努力,千里自同风1 小时前
如何使用 Promise.all() 处理异步并发操作?
开发语言·前端·javascript
营赢盈英1 小时前
How to detect if <html> tag has a class in child Angular component
前端·javascript·css·html·angular.js
Achieve - 前端实验室1 小时前
深入浅出 ES Module
前端·javascript
littleplayer1 小时前
Combine 基本使用指南
前端