真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何處理微信小程序BindTap快速連續(xù)點(diǎn)擊目標(biāo)頁面跳轉(zhuǎn)多次的問題

這篇文章給大家分享的是有關(guān)如何處理微信小程序BindTap快速連續(xù)點(diǎn)擊目標(biāo)頁面跳轉(zhuǎn)多次的問題的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都創(chuàng)新互聯(lián)主營波密網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都app開發(fā),波密h5小程序設(shè)計搭建,波密網(wǎng)站營銷推廣歡迎波密等地區(qū)企業(yè)咨詢

問題描述:

1)wxml片段


  連續(xù)點(diǎn)擊,加載多次


  連續(xù)點(diǎn)擊,加載一次

2)js代碼片段

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

3)快速,連續(xù)點(diǎn)擊“連續(xù)點(diǎn)擊,加載多次”文本串時,我們會發(fā)現(xiàn),目標(biāo)頁面loadMulti/index頁面被加載了N次,需要點(diǎn)擊N次返回,才可以返回到主頁面。

問題原因剖析:

小程序基于MINA框架,該框架的核心框架的核心是一個響應(yīng)的數(shù)據(jù)綁定系統(tǒng),整個系統(tǒng)分為兩塊視圖層(View)和邏輯層(App Service),框架可以讓數(shù)據(jù)與視圖非常簡單地保持同步。當(dāng)做數(shù)據(jù)修改的時候,只需要在邏輯層修改數(shù)據(jù),視圖層就會做相應(yīng)的更新;當(dāng)點(diǎn)擊按鈕的時候,視圖層會發(fā)送 bindtap的事件給邏輯層,邏輯層找到對應(yīng)的事件處理函數(shù)loadMulti執(zhí)行。

由于視圖層發(fā)送bindtap事件給邏輯層并找到對應(yīng)的處理函數(shù)需要時間T1,找到對應(yīng)的處理函數(shù)loadMulti后,執(zhí)行l(wèi)oadMulti函數(shù):wx.navigateTo, hide 原頁面,需要時間T2,如果在T1+T2時間內(nèi),快速連續(xù)點(diǎn)擊N次,完全可以加載顯示N次目標(biāo)頁面。

解決方案:

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

1)loadOnce事件處理函數(shù)中,設(shè)置pageLoading = true

2)頁面的onShow事件中,設(shè)置pageLoading = false

其實我們可以封裝成方法:

/**

*解決連續(xù)點(diǎn)擊多次沖出觸發(fā)事件

*/

function throttle(fn, gapTime) {

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

    gapTime = 1500

  }

  let _lastTime = null

  // 返回新的函數(shù)

  return function () {

    let _nowTime = + new Date()

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

      fn.apply(this, arguments)  //將this和參數(shù)傳給原函數(shù)

      _lastTime = _nowTime

    }

  }

}
tap
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)

})

感謝各位的閱讀!關(guān)于“如何處理微信小程序BindTap快速連續(xù)點(diǎn)擊目標(biāo)頁面跳轉(zhuǎn)多次的問題”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


本文標(biāo)題:如何處理微信小程序BindTap快速連續(xù)點(diǎn)擊目標(biāo)頁面跳轉(zhuǎn)多次的問題
URL分享:http://weahome.cn/article/jgiojj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部