微信小程序BindTap快速連續(xù)點(diǎn)擊目標(biāo)頁(yè)面跳轉(zhuǎn)多次問(wèn)題處理
問(wèn)題描述:
1)wxml片段
<view bindtap="loadMulti"> <text>連續(xù)點(diǎn)擊,加載多次</text> </view> <view bindtap="loadOnce"> <text>連續(xù)點(diǎn)擊,加載一次</text> </view>
2)js代碼片段
loadMulti:function(e) { wx.navigateTo({ url: '/pages/loadMulti/index', }) },
3)快速,連續(xù)點(diǎn)擊“連續(xù)點(diǎn)擊,加載多次”文本串時(shí),我們會(huì)發(fā)現(xiàn),目標(biāo)頁(yè)面loadMulti/index頁(yè)面被加載了N次,需要點(diǎn)擊N次返回,才可以返回到主頁(yè)面。
問(wèn)題原因剖析:
小程序基于MINA框架,該框架的核心框架的核心是一個(gè)響應(yīng)的數(shù)據(jù)綁定系統(tǒng),整個(gè)系統(tǒng)分為兩塊視圖層(View)和邏輯層(App Service),框架可以讓數(shù)據(jù)與視圖非常簡(jiǎn)單地保持同步。當(dāng)做數(shù)據(jù)修改的時(shí)候,只需要在邏輯層修改數(shù)據(jù),視圖層就會(huì)做相應(yīng)的更新;當(dāng)點(diǎn)擊按鈕的時(shí)候,視圖層會(huì)發(fā)送 bindtap的事件給邏輯層,邏輯層找到對(duì)應(yīng)的事件處理函數(shù)loadMulti執(zhí)行。
由于視圖層發(fā)送bindtap事件給邏輯層并找到對(duì)應(yīng)的處理函數(shù)需要時(shí)間T1,找到對(duì)應(yīng)的處理函數(shù)loadMulti后,執(zhí)行l(wèi)oadMulti函數(shù):wx.navigateTo, hide 原頁(yè)面,需要時(shí)間T2,如果在T1+T2時(shí)間內(nèi),快速連續(xù)點(diǎn)擊N次,完全可以加載顯示N次目標(biāo)頁(yè)面。
解決方案:
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)頁(yè)面的onShow事件中,設(shè)置pageLoading = false
其實(shí)我們可以封裝成方法:
/** *解決連續(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 } } }
<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) })
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS判斷、校驗(yàn)MAC地址的2個(gè)實(shí)例
這篇文章主要介紹了JS判斷、校驗(yàn)MAC地址的2個(gè)實(shí)例,需要的朋友可以參考下2014-05-05本地存儲(chǔ)cookie、localStorage和sessionStorage示例詳解
cookie、localStorage?和?sessionStorage都是在客戶端存儲(chǔ)數(shù)據(jù)的方式,但它們之間有一些區(qū)別,下面這篇文章主要給大家介紹了關(guān)于JavaScript中cookie、localStorage和sessionStorage的相關(guān)資料,需要的朋友可以參考下2024-03-03JS實(shí)現(xiàn)3D圖片旋轉(zhuǎn)展示效果代碼
這篇文章主要介紹了JS實(shí)現(xiàn)3D圖片旋轉(zhuǎn)展示效果代碼,可實(shí)現(xiàn)頁(yè)面元素的3D旋轉(zhuǎn)變換效果,涉及JavaScript動(dòng)態(tài)數(shù)學(xué)運(yùn)算的相關(guān)技巧,需要的朋友可以參考下2015-09-09Javascript中八種遍歷方法的執(zhí)行速度深度對(duì)比
關(guān)于數(shù)組或?qū)ο蟊闅v,相信很多人都沒(méi)有深入觀察過(guò)執(zhí)行效率。這是一個(gè)曾在群里吵翻天的話題,讀懂后你將成為遍歷效率話題的大師。下面這篇文章主要介紹了Javascript中八種遍歷方法執(zhí)行速度深度對(duì)比的相關(guān)資料,需要的朋友可以參考下。2017-04-04以JSON形式將JS中Array對(duì)象數(shù)組傳至后臺(tái)的方法
業(yè)務(wù)是需要將前臺(tái)jQuery easyUI DataGrid列表中所選的若干行的數(shù)據(jù)傳到后臺(tái)進(jìn)行update操作,具體的實(shí)現(xiàn)如下,感興趣的朋友可以參考下2014-01-01js canvas實(shí)現(xiàn)二維碼和圖片合成的海報(bào)
這篇文章主要為大家詳細(xì)介紹了js canvas實(shí)現(xiàn)二維碼和圖片合成的海報(bào),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11用Webpack構(gòu)建Vue項(xiàng)目的實(shí)踐
這篇文章主要介紹了用Webpack構(gòu)建Vue項(xiàng)目的實(shí)踐,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11