经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 微信小程序 » 查看文章
微信小程序BindTap快速连续点击目标页面跳转多次问题处理
来源:jb51  时间:2019/4/8 12:18:30  对本文有异议

问题描述:

1)wxml片段

  1. <view bindtap="loadMulti">
  2. <text>连续点击,加载多次</text>
  3. </view>
  4. <view bindtap="loadOnce">
  5. <text>连续点击,加载一次</text>
  6. </view>
  7.  

2)js代码片段

  1. loadMulti:function(e) {
  2. wx.navigateTo({
  3. url: '/pages/loadMulti/index',
  4. })
  5. },

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

问题原因剖析:

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

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

解决方案:

  1. loadOnce:function(e) {
  2. if (!this.pageLoading) {
  3. this.pageLoading = !0;
  4. wx.navigateTo({
  5. url: '/pages/loadOnce/index',
  6. })
  7. }
  8. },
  9. onShow: function() {
  10. this.pageLoading = !1;
  11. }

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

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

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

  1. /**
  2.  
  3. *解决连续点击多次冲出触发事件
  4.  
  5. */
  6.  
  7. function throttle(fn, gapTime) {
  8.  
  9. if (gapTime == null || gapTime == undefined) {
  10.  
  11. gapTime = 1500
  12.  
  13. }
  14.  
  15. let _lastTime = null
  16.  
  17. // 返回新的函数
  18.  
  19. return function () {
  20.  
  21. let _nowTime = + new Date()
  22.  
  23. if (_nowTime - _lastTime > gapTime || !_lastTime) {
  24.  
  25. fn.apply(this, arguments) //将this和参数传给原函数
  26.  
  27. _lastTime = _nowTime
  28.  
  29. }
  30.  
  31. }
  32.  
  33. }
  1. <button bindtap='tap' data-key='abc'>tap</button>

  1. const util = require('../../utils/util.js')
  2.  
  3. Page({
  4.  
  5. data: {
  6.  
  7. text: 'tomfriwel'
  8.  
  9. },
  10.  
  11. onLoad: function (options) {
  12.  
  13. },
  14.  
  15. tap: util.throttle(function (e) {
  16.  
  17. console.log(this)
  18.  
  19. console.log(e)
  20.  
  21. console.log((new Date()).getSeconds())
  22.  
  23. }, 1000)
  24.  
  25. })

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号