Vue3+TS项目给el-button统一封装一个点击后转圈效果的钩子函数按钮防抖

前言

每个按钮都要单独定义一个loading变量,并且在接口请求前修改为true,接口响应后再修改为false,封装后这段重复的逻辑就可以统一管理不用每次都写一遍了。

效果

新建一个公共的src\common.ts

import { ref } from "vue"

export function useBtnLoading() {
  const isLoading = ref(false)
  const handleClick = async (action: () => Promise<void>) => {
    isLoading.value = true
    try {
      await action()
    } finally {
      isLoading.value = false
    }
  }

  return {
    isLoading,
    handleClick,
  }
}

页面中使用

<el-button type="primary" :loading="btnLoading" @click="btnClick">提交</el-button>
import { useBtnLoading } from '@/utils/common'

const { isLoading: btnLoading, handleClick } = useBtnLoading();

const btnClick = () => {
  handleClick(() => reqFn())
}

const reqFn = () => {
  // 模拟调用接口
  return new Promise((resolve, reject) => {
    setTimeout(() => resolve(123), 2000);
  });
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值