详解小程序如何避免多次点击,重复触发事件


Posted in Javascript onApril 08, 2019

作为前端开发,我们经常会遇到的场景,比如用户点击获取验证码按钮时,没有反应,大部分用户都会接着点击,这就会造成用户收到多条验证码,这是因为后台api请求比较慢,而客户端体验又做得不到位,导致用户以为没点击到或者是页面假死,在上次请求还没处理完,就再次点击按钮。这对于我们开发来说,这是bug。

如何解决或避免这个问题呢?一般来说有两种情况。

1、点击事件是执行网络请求(提交评论,验证码,支付)

这种情况下可以在请求执行之前显示一个模式的加载框,请求完成后再关闭加载框。

由于小程序在1.1.0版本基础库才支持wx.showLoading,因此需要对低版本做兼容处理,代码如下:

function showLoading(message) {
 if (wx.showLoading) {
  // 基础库 1.1.0 微信6.5.6版本开始支持,低版本需做兼容处理
  wx.showLoading({
   title: message,
   mask: true
  });
 } else {
  // 低版本采用Toast兼容处理并将时间设为20秒以免自动消失
  wx.showToast({
   title: message,
   icon: 'loading',
   mask: true,
   duration: 20000
  });
 }
}
 
function hideLoading() {
 if (wx.hideLoading) {
  // 基础库 1.1.0 微信6.5.6版本开始支持,低版本需做兼容处理
  wx.hideLoading();
 } else {
  wx.hideToast();
 }
}

我们可以将显示加载框和关闭加载框的代码放在公共的代码里面比如util,然后在使用时直接调用即可。

function request() {
 util.showLoading('加载中...');
 wx.request({
  url: app.globalData.host + 'xxx',
  data: {...},
  method: 'GET',
  success: function (res) {
   util.hideLoading()
   ...
  },
  fail: function (res) {
   util.hideLoading()
   ...
  }
 })
}

2、点击事件是页面跳转

当点击事件需要页面跳转时,不太适合显示加载框,但小程序的页面跳转并不是很快,如果不作处理又会导致用户反复点击打开多个页面,这里可以使用限制按钮或控件的点击间隔的方式处理,同样可以将这个方法放到公共的代码里面比如util,然后在使用时直接调用即可。

function buttonClicked(self) {
 self.setData({
  buttonClicked: true
 })
 setTimeout(function () {
  self.setData({
   buttonClicked: false
  })
 }, 500)
}

首先需要在页面对应的js文件里面增加一个buttonClicked数据对象,然后在点击事件里面调用上述方法。

Page({
 data: {
  buttonClicked: false
 },
 click: function (e) {
  util.buttonClicked(this);
  var id = e.currentTarget.dataset.id;
  wx.navigateTo({
   url: '../detail/detail?id=' + id
  })
 },
})

另外,在wxml的点击控件中通过buttonClicked判断是否可以点击,可以用bindtap也可以用disabled

<view bindtap="{{!buttonClicked?'click':''}}" data-id="{{id}}" />
<button bindtap="{{!buttonClicked?'click':''}}" data-id="{{id}}" />
<button bindtap="click" disabled="buttonClicked" data-id="{{id}}" />

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 动态添加表格行 使用模板、标记
Oct 24 Javascript
基于JQuery的简单实现折叠菜单代码
Sep 15 Javascript
Jquery实现带动画效果的经典二级导航菜单
Mar 22 Javascript
jQuery避免$符和其他JS库冲突的方法对比
Feb 20 Javascript
JS函数重载的解决方案
May 13 Javascript
JavaScript设计模式之建造者模式介绍
Dec 28 Javascript
纯JS前端实现分页代码
Jun 21 Javascript
jQuery EasyUI右键菜单实现关闭标签/选项卡
Oct 10 Javascript
纯javaScript、jQuery实现个性化图片轮播【推荐】
Jan 08 Javascript
JavaScript实现图像模糊化的方法实例
Jan 15 Javascript
vue使用jsonp抓取qq音乐数据的方法
Jun 21 Javascript
使用 Jest 和 Supertest 进行接口端点测试实例详解
Apr 25 Javascript
「中高级前端面试」JavaScript手写代码无敌秘籍(推荐)
Apr 08 #Javascript
微信小程序BindTap快速连续点击目标页面跳转多次问题处理
Apr 08 #Javascript
vue.js实现会动的简历(包含底部导航功能,编辑功能)
Apr 08 #Javascript
微信小程序视图控件与bindtap之间的问题的解决
Apr 08 #Javascript
微信小程序实现bindtap等事件传参
Apr 08 #Javascript
详解vue中axios请求的封装
Apr 08 #Javascript
使用taro开发微信小程序遇到的坑总结
Apr 08 #Javascript
You might like
网站加速 PHP 缓冲的免费实现方法
2006/10/09 PHP
php笔记之:php函数range() round()和list()的使用说明
2013/04/26 PHP
在PHP中运行Linux命令并启动SSH服务的例子
2014/06/12 PHP
分享PHP计算两个日期相差天数的代码
2015/12/23 PHP
Yii中创建自己的Widget实例
2016/01/05 PHP
php使用curl实现简单模拟提交表单功能
2017/05/15 PHP
使用PHPStorm+XDebug搭建单步调试环境
2017/11/19 PHP
通过JavaScript控制字体大小的代码
2011/10/04 Javascript
JavaScript高级程序设计 读书笔记之十 本地对象Date日期
2012/02/27 Javascript
NodeJS学习笔记之Connect中间件模块(二)
2015/01/27 NodeJs
在AngularJS中使用AJAX的方法
2015/06/17 Javascript
设计模式中的组合模式在JavaScript程序构建中的使用
2016/05/18 Javascript
Javascript实现汉字和拼音互转的终极方案
2016/10/19 Javascript
理解 javascript 中的函数表达式与函数声明
2017/07/07 Javascript
js实现音乐播放控制条
2017/09/09 Javascript
node作为中间服务层如何发送请求(发送请求的实现方法详解)
2018/01/02 Javascript
pace.js和NProgress.js两个加载进度插件的一点小总结
2018/01/31 Javascript
通过vue手动封装on、emit、off的代码详解
2019/05/29 Javascript
vue项目中js-cookie的使用存储token操作
2020/11/13 Javascript
jQuery实现动态操作table行
2020/11/23 jQuery
[02:26]2016国际邀请赛8月3日开战 中国军团出征西雅图
2016/08/02 DOTA
python 全文检索引擎详解
2017/04/25 Python
python微元法计算函数曲线长度的方法
2018/11/08 Python
python:目标检测模型预测准确度计算方式(基于IoU)
2020/01/18 Python
超全Python图像处理讲解(多模块实现)
2020/04/13 Python
python 写函数在一定条件下需要调用自身时的写法说明
2020/06/01 Python
python实现邮件循环自动发件功能
2020/09/11 Python
python中用ctypes模拟点击的实例讲解
2020/11/26 Python
python3.9实现pyinstaller打包python文件成exe
2020/12/13 Python
产品促销活动策划书
2014/01/15 职场文书
户外活动策划方案
2014/03/12 职场文书
2014年母亲节演讲稿范文
2014/05/07 职场文书
青年教师个人总结
2015/02/11 职场文书
高中家长意见怎么写
2015/06/03 职场文书
法定代表人资格证明书
2015/06/18 职场文书
2019中小学生安全过暑期倡议书
2019/06/24 职场文书