vue uniapp 防止按钮多次点击(类似于防抖节流)

common文件并创建anti-shake.js文件

复制代码
// 防止处理多次点击
function noMultipleClicks(methods, info) {
    // methods是需要点击后需要执行的函数, info是点击需要传的参数
    let that = this;
    if (that.noClick) {
        // 第一次点击
        that.noClick= false;
        if(info && info !== '') {
            // info是执行函数需要传的参数
            methods(info);
        } else {
            methods();
        }
        setTimeout(()=> {
            that.noClick= true;
        }, 2000)//时间可以自己定义
    } else {
        // 这里是重复点击的判断
    }
}
//导出
export default {
    noMultipleClicks,//禁止多次点击
}

man.js文件中引入

复制代码
//配置公共方法
import common from './common/common.js'
Vue.prototype.$noMultipleClicks = common.noMultipleClicks;

页面里使用即可

不传参,直接传一个方法就行

复制代码
//记得在data中挂载   noClick:true,否则点击会失效
data() {
    return {
        noClick:true,
    }
},
 
<view class="bottom-btn-box">
    <view class="submit-btn" @click="$noMultipleClicks(commitWork)">提交</view>
</view>
 
methods:{
//提交方法
    commitWork(){
        
    }           
}

带参数,传一个方法和一个参数就行

复制代码
//记得在data中挂载   noClick:true,否则点击会失效
data() {
    return {
        noClick:true,
    }
},
 
<view class="bottom-btn-box">
    <view class="pay" @click.stop="$noMultipleClicks(goPay, item)" >支付</view>
</view>
 
methods:{
    goPay(item){
        //balabala
    }           
}
相关推荐
2501_9151063221 分钟前
iOS App 测试工具全景分析,构建从开发调试到线上监控的多阶段工具链体系
android·测试工具·ios·小程序·uni-app·iphone·webview
Heo42 分钟前
关于XSS和CSRF,面试官更喜欢这样的回答!
前端·javascript·面试
dchen771 小时前
uniapp实现上拉刷新和下拉刷新的两种方式
uni-app
7***A4431 小时前
Vue自然语言处理应用
前端·vue.js·自然语言处理
徐小夕1 小时前
耗时一周,我把可视化+零代码+AI融入到了CRM系统,使用体验超酷!
javascript·vue.js·github
5***a9751 小时前
React Native性能优化技巧
javascript·react native·react.js
A3608_(韦煜粮)2 小时前
深入理解React Hooks设计哲学与实现原理:从闭包陷阱到并发模式
javascript·性能优化·react·前端开发·react hooks·并发模式·自定义hooks
玉宇夕落2 小时前
🔁 字符串反转 × 两数之和:前端面试高频题深度拆解(附5种反转写法 + 哈希优化)
javascript
神秘的猪头2 小时前
🧱 深入理解栈(Stack):原理、实现与实战应用
前端·javascript·面试
明教教主张5G2 小时前
Vue响应式原理(13)-ref实现原理解析
前端·vue.js