這篇文章給大家分享的是有關(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 } } }
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é)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!