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

问题描述:

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



阅读更多

扫码向博主提问

老马历写记

非学,无以致疑;非问,无以广识
  • 擅长领域:
  • 系统架构
  • 数据库
  • java
  • js前端
  • 全栈开发
去开通我的Chat快问
换一批

没有更多推荐了,返回首页