91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

如何處理微信小程序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

建水县| 洛宁县| 九寨沟县| 寻乌县| 会同县| 三明市| 江阴市| 黄山市| 沅陵县| 新邵县| 谢通门县| 开江县| 大港区| 龙陵县| 鹿泉市| 安阳县| 乌鲁木齐县| 西昌市| 大名县| 朔州市| 长泰县| 澜沧| 三明市| 曲水县| 涡阳县| 保康县| 新泰市| 田东县| 南宁市| 沙坪坝区| 康定县| 开江县| 色达县| 盐城市| 五常市| 林口县| 南木林县| 揭东县| 张北县| 福贡县| 诸暨市|