uni-app多次触发事件,防止重复点击

复制代码
在uni-app中,经常会碰到多次触发事件,重复点击,导致造成业务出现问题。
虽然在后端可以进行操作,防止业务问题。那么前端该如何实现呢?

1.在根目录下新建common文件并创建noclick.js文件

javascript 复制代码
// 防止处理多次点击
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,//禁止多次点击
}

2.man.js文件中引入

javascript 复制代码
//配置公共方法  防治多次点击
import noclick from 'common/noclick.js'
Vue.prototype.$noMultipleClicks = noclick.noMultipleClicks;

3.在页面中使用

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

javascript 复制代码
//记得在data中挂载   noClick:true,否则点击会失效
data() {
    return {
        noClick:true,
    }
}, 

<view class="bottom-btn-box">
    <view class="submit-btn" @click="$noMultipleClicks(commitWork)">提交</view>
</view>

methods:{
//提交方法
    commitWork(){       

    }
}

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

javascript 复制代码
//记得在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
    }
}
相关推荐
ZC跨境爬虫几秒前
海南大学交友平台开发实战 day9(头像上传存入 SQLite+BLOB 存储 + 前后端联调避坑全记录)
前端·数据库·python·sqlite
落魄江湖行17 分钟前
基础篇六 Nuxt4 状态管理:useState 的正确用法
前端·vue.js·typescript·nuxt4
jerrywus22 分钟前
手机控制 AI 编程?Paseo 让你随时随地跑 Claude Code / Codex
前端·agent·claude
GISer_Jing33 分钟前
前端视频技术全解析:从编解码到渲染优化
前端·音视频·状态模式
LIO38 分钟前
Vue3 + Pinia 完整使用教程(企业级)
前端·vue.js
军军君0140 分钟前
数字孪生监控大屏实战模板:智慧城市大屏
前端·vue.js·typescript·前端框架·echarts·智慧城市·大屏展示
计算机学姐44 分钟前
基于SpringBoot的房屋交易系统
java·vue.js·spring boot·后端·spring·intellij-idea·mybatis
CDN3601 小时前
高防切换后网站打不开?DNS 解析与回源路径故障排查
前端·网络·数据库
信也科技布道师1 小时前
把7个页面变成1段对话:AI如何重构借款流程
前端·人工智能·重构·架构·交互·用户体验
27669582921 小时前
携程旅行 token1005
java·linux·前端·javascript·携程旅行·token1005·携程酒店