微信小程序BindTap快速连续点击目标页面跳转多次问题处理


Posted in Javascript onApril 08, 2019

问题描述:

1)wxml片段

<view bindtap="loadMulti">
  <text>连续点击,加载多次</text>
</view>
<view bindtap="loadOnce">
  <text>连续点击,加载一次</text>
</view>

2)js代码片段

loadMulti:function(e) {
  wx.navigateTo({
    url: '/pages/loadMulti/index',
  })
},

3)快速,连续点击“连续点击,加载多次”文本串时,我们会发现,目标页面loadMulti/index页面被加载了N次,需要点击N次返回,才可以返回到主页面。

问题原因剖析:

小程序基于MINA框架,该框架的核心框架的核心是一个响应的数据绑定系统,整个系统分为两块视图层(View)和逻辑层(App Service),框架可以让数据与视图非常简单地保持同步。当做数据修改的时候,只需要在逻辑层修改数据,视图层就会做相应的更新;当点击按钮的时候,视图层会发送 bindtap的事件给逻辑层,逻辑层找到对应的事件处理函数loadMulti执行。

由于视图层发送bindtap事件给逻辑层并找到对应的处理函数需要时间T1,找到对应的处理函数loadMulti后,执行loadMulti函数:wx.navigateTo, hide 原页面,需要时间T2,如果在T1+T2时间内,快速连续点击N次,完全可以加载显示N次目标页面。

解决方案:

loadOnce:function(e) {
  if (!this.pageLoading) {
   this.pageLoading = !0;
   wx.navigateTo({
    url: '/pages/loadOnce/index',
   })
  }
 },
 onShow: function() {
  this.pageLoading = !1;
}

1)loadOnce事件处理函数中,设置pageLoading = true

2)页面的onShow事件中,设置pageLoading = false

其实我们可以封装成方法:

/**

*解决连续点击多次冲出触发事件

*/

function throttle(fn, gapTime) {

  if (gapTime == null || gapTime == undefined) {

    gapTime = 1500

  }

  let _lastTime = null

  // 返回新的函数

  return function () {

    let _nowTime = + new Date()

    if (_nowTime - _lastTime > gapTime || !_lastTime) {

      fn.apply(this, arguments)  //将this和参数传给原函数

      _lastTime = _nowTime

    }

  }

}
<button bindtap='tap' data-key='abc'>tap</button>

const util = require('../../utils/util.js')

Page({

  data: {

    text: 'tomfriwel'

  },

  onLoad: function (options) {

  },

  tap: util.throttle(function (e) {

    console.log(this)

    console.log(e)

    console.log((new Date()).getSeconds())

  }, 1000)

})

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

Javascript 相关文章推荐
JavaScript中使用构造函数实现继承的代码
Aug 12 Javascript
JavaScript中的toLocaleLowerCase()方法使用详解
Jun 06 Javascript
JS弹出对话框实现方法(三种方式)
Dec 18 Javascript
js获取json中key所对应的value值的简单方法
Jun 17 Javascript
理解 Node.js 事件驱动机制的原理
Aug 16 Javascript
JavaScript表格隔行变色和Tab标签页特效示例【附jQuery版】
Jul 11 jQuery
vue-devtools的安装和使用步骤详解
Oct 17 Javascript
node爬取新型冠状病毒的疫情实时动态
Feb 06 Javascript
使用Vue实现简单计算器
Feb 25 Javascript
JS实现无限轮播无倒退效果
Sep 21 Javascript
JS pushlet XMLAdapter适配器用法案例解析
Oct 16 Javascript
vue实现锚点定位功能
Jun 29 Vue.js
vue.js实现会动的简历(包含底部导航功能,编辑功能)
Apr 08 #Javascript
微信小程序视图控件与bindtap之间的问题的解决
Apr 08 #Javascript
微信小程序实现bindtap等事件传参
Apr 08 #Javascript
详解vue中axios请求的封装
Apr 08 #Javascript
使用taro开发微信小程序遇到的坑总结
Apr 08 #Javascript
vue+element+Java实现批量删除功能
Apr 08 #Javascript
如何为你的JavaScript代码日志着色详解
Apr 08 #Javascript
You might like
PHP源码分析之变量的存储过程分解
2014/07/03 PHP
php递归json类实例
2014/12/02 PHP
php实现搜索一维数组元素并删除二维数组对应元素的方法
2015/07/06 PHP
php微信公众号开发之关键词回复
2018/10/20 PHP
PDO::query讲解
2019/01/29 PHP
PHP 实现base64编码文件上传出现问题详解
2020/09/01 PHP
ASP.NET中基于JQUERY的高性能的TreeView补充
2011/02/23 Javascript
jquery删除数据记录时的弹出提示效果
2014/05/06 Javascript
JS修改iframe页面背景颜色的方法
2015/04/01 Javascript
深入浅析JavaScript中的作用域和上下文
2016/03/26 Javascript
JavaScript程序中的流程控制语句用法总结
2016/05/23 Javascript
React Native模块之Permissions权限申请的实例相机
2017/09/28 Javascript
vue-cli项目根据线上环境分别打出测试包和生产包
2018/05/23 Javascript
微信小程序实现上传图片裁剪图片过程解析
2019/08/22 Javascript
如何修改Vue打包后文件的接口地址配置的方法
2020/04/22 Javascript
koa2 数据api中间件设计模型的实现方法
2020/07/13 Javascript
快速解决element的autofocus失效问题
2020/09/08 Javascript
[22:20]初生之犊-TI4第5名LGD战队纪录片
2014/08/13 DOTA
Python中if __name__ == &quot;__main__&quot;详细解释
2014/10/21 Python
Python import自定义模块方法
2015/02/12 Python
Python易忽视知识点小结
2015/05/25 Python
Python下调用Linux的Shell命令的方法
2018/06/12 Python
美国独家设计师眼镜在线光学商店:Glasses Gallery
2017/12/28 全球购物
小学教师管理制度
2014/01/18 职场文书
银行员工职业规划范文
2014/01/21 职场文书
学习雷锋月活动总结
2014/07/03 职场文书
建筑学专业自荐书
2014/07/09 职场文书
2014年英语教学工作总结
2014/12/17 职场文书
劳保用品管理制度范本
2015/08/06 职场文书
2016大学生党校学习心得体会
2016/01/06 职场文书
2019最新版劳务派遣管理制度
2019/08/16 职场文书
详解CSS不定宽溢出文本适配滚动
2021/05/24 HTML / CSS
Redis集群新增、删除节点以及动态增加内存的方法
2021/09/04 Redis
Django基础CBV装饰器和中间件
2022/03/22 Python
清空 Oracle 安装记录并重新安装
2022/04/26 Oracle
MySQL主从切换的超详细步骤
2022/06/28 MySQL