微信小程序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 测试及效验工具
Apr 18 Javascript
通过javascript的匿名函数来分析几段简单有趣的代码
Jun 29 Javascript
JS重要知识点小结
Nov 06 Javascript
对JavaScript中this指针的新理解分享
Jan 31 Javascript
JavaScript实现广告弹窗效果
Aug 09 Javascript
jQuery插件HighCharts实现的2D堆条状图效果示例【附demo源码下载】
Mar 14 Javascript
JS+canvas动态绘制饼图的方法示例
Sep 12 Javascript
jQuery基于闭包实现的显示与隐藏div功能示例
Jun 09 jQuery
生产制造追溯系统之再说条码打印
Jun 03 Javascript
vue项目部署到nginx/tomcat服务器的实现
Aug 26 Javascript
vue-cli点击实现全屏功能
Mar 07 Javascript
Vue elementUI表单嵌套表格并对每行进行校验详解
Feb 18 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脚本代码
2011/02/19 PHP
fgetcvs在linux的问题
2012/01/15 PHP
php可应用于面包屑导航的递归寻找家谱树实现方法
2015/02/02 PHP
PHP获取当前文件的父目录方法汇总
2016/07/21 PHP
php实现登陆模块功能示例
2016/10/20 PHP
Extjs Ajax 乱码问题解决方案
2009/04/15 Javascript
jquery URL参数判断,确定菜单样式
2010/05/31 Javascript
ExtJS 入门
2010/10/29 Javascript
基于JQUERY的两个ListBox子项互相调整的实现代码
2011/05/07 Javascript
jquery教程限制文本框只能输入数字和小数点示例分享
2014/01/13 Javascript
javascript break指定标签打破多层循环示例
2014/01/20 Javascript
js二维数组排序的简单示例代码
2014/01/24 Javascript
jQuery中:checkbox选择器用法实例
2015/01/03 Javascript
深入理解JavaScript系列(21):S.O.L.I.D五大原则之接口隔离原则ISP详解
2015/03/05 Javascript
原生JS实现美图瀑布流布局赏析
2015/09/07 Javascript
JS实现兼容性好,带缓冲的动感网页右键菜单效果
2015/09/18 Javascript
轻松实现JavaScript图片切换
2016/01/12 Javascript
Jquery中巧用Ajax的beforeSend方法
2016/01/20 Javascript
如何利用Promises编写更优雅的JavaScript代码
2016/05/17 Javascript
js判断空对象的实例(超简单)
2016/07/26 Javascript
Vue.js实现表格动态增加删除的方法(附源码下载)
2017/01/20 Javascript
Bootstrap栅格系统的使用详解
2017/10/30 Javascript
vue地区选择组件教程详解
2018/05/04 Javascript
JS实现点击发送验证码 xx秒后重新发送功能
2019/07/30 Javascript
[00:44]2016完美“圣”典 风云人物:Mikasa宣传片
2016/12/07 DOTA
Python遍历文件夹 处理json文件的方法
2019/01/22 Python
pycharm+PyQt5+python最新开发环境配置(踩坑)
2019/02/11 Python
python字符串循环左移
2019/03/08 Python
python单向链表的基本实现与使用方法【定义、遍历、添加、删除、查找等】
2019/10/24 Python
Python实现序列化及csv文件读取
2020/01/19 Python
requests在python中发送请求的实例讲解
2021/02/17 Python
Java程序员面试题
2016/09/27 面试题
UNIX文件系统常用命令
2012/05/25 面试题
应届电子商务毕业自荐书范文
2014/02/11 职场文书
工程索赔意向书
2014/08/30 职场文书
导游词之吉林吉塔
2019/11/11 职场文书