uniapp实现按钮防重复点击(防抖)完整解决方案

需求:

防止用户连续点击按钮,造成短时间内发起多次请求,对后台服务造成压力;

防止第一次请求还没执行完,第二次请求就发起了。

实现方案:

按钮disable禁用+定时器按钮恢复

其中定义disable变量主要是为了保证逻辑的按顺序执行,定时器恢复主要是为了防止按钮重复点击,因为如果请求响应的特别快,用户还是有可能在短时间内执行多次请求,所以二者缺一不可,这才是完美解决方案

关键代码

按钮:

复制代码
<view @click="submit"  :class="{ disabledBtn: isSubmitting }">提交</view>

定义数据:

复制代码
data() {
    return {
      isSubmitting: false,
      }
}

点击事件:

复制代码
submit(){
  // 防抖提交
   if (this.isSubmitting){
     return
   }
   this.isSubmitting = true;
   try {
     // 这是我自己封装的api工具js,可以换成自己的请求,恢复按钮的代码放在请求执行完成之后即可
     this.$u.api.testRequestApi(this.model).then(res => {
       if(res.success){
         uni.showToast({
           title: '操作成功',
           icon: 'none',
           duration: 3000
         });
       }
       setTimeout(() => {
         this.isSubmitting = false;
       }, 1500);
     });
   } catch (error) {
     // 这里不要在finally里写false,因为我们要实现等请求结束后才可以点击下一次
     this.isSubmitting = false;
   }
 },

按钮置灰不可点击(关键)

复制代码
<style lang="scss" scoped>
	.disabledBtn {
	  pointer-events: none;
	  opacity: 0.6;
	}
</style>
相关推荐
2501_9151063214 小时前
“HTTPS Everywhere” 的工程化实践,从全面加密到排查与真机取证
网络协议·http·ios·小程序·https·uni-app·iphone
Felicity_Gao16 小时前
uni-app App升级功能实现
前端·学习·uni-app
00后程序员张18 小时前
Web 前端工具全流程指南 从开发到调试的完整生态体系
android·前端·ios·小程序·uni-app·iphone·webview
aiguangyuan19 小时前
uni-app开发入门手册
uni-app·移动开发·前端开发
游戏开发爱好者81 天前
iOS 崩溃日志分析工具全指南,多工具协同构建稳定性分析体系
android·macos·ios·小程序·uni-app·cocoa·iphone
Felicity_Gao1 天前
uni-app VOD 与 COS 选型、开发笔记
前端·笔记·uni-app
00后程序员张2 天前
如何提高 IPA 安全性 多工具组合打造可复用的 iOS 加固与反编译防护体系(IPA 安全 iOS 加固 无源码混淆 Ipa Guard 实战)
android·安全·ios·小程序·uni-app·iphone·webview
游戏开发爱好者82 天前
Fiddler抓包实战教程 从安装配置到代理设置,详解Fiddler使用方法与调试技巧(HTTPHTTPS全面指南)
前端·测试工具·小程序·https·fiddler·uni-app·webview
望风的懒蜗牛2 天前
android studio开发UniComponent<SurfaceView>组件
android·uni-app·android studio
2501_916007472 天前
Fastlane 结合 开心上架 命令行版本实现跨平台上传发布 iOS App
android·ios·小程序·https·uni-app·iphone·webview