亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何處理微信小程序BindTap快速連續點擊目標頁面跳轉多次的問題

發布時間:2021-07-19 09:36:42 來源:億速云 閱讀:589 作者:小新 欄目:web開發

這篇文章給大家分享的是有關如何處理微信小程序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

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

/**

*解決連續點擊多次沖出觸發事件

*/

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)

})

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

潞西市| 巩义市| 响水县| 石渠县| 观塘区| 兴宁市| 宜都市| 安国市| 遂宁市| 凤冈县| 梨树县| 深圳市| 晋州市| 兴海县| 莱芜市| 大关县| 沙田区| 嘉义市| 石林| 根河市| 桐城市| 长沙市| 巴塘县| 凤山市| 巴马| 雅江县| 永定县| 克山县| 呼伦贝尔市| 赞皇县| 柳州市| 云霄县| 根河市| 仙桃市| 肥乡县| 桂阳县| 通榆县| 鲜城| 东山县| 永平县| 黄大仙区|