微信小程序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)文章
鼠標(biāo)焦點(diǎn)離開(kāi)文本框時(shí)驗(yàn)證的js代碼
本文為大家介紹下利用js來(lái)驗(yàn)證文本框的值,當(dāng)鼠標(biāo)焦點(diǎn)離開(kāi)文本框時(shí)進(jìn)行驗(yàn)證,示例代碼如下,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-07-07
悄悄用腳本檢查你訪問(wèn)過(guò)哪些網(wǎng)站的代碼
YouPorn是YouTube的成人自拍版,Alexa排名61。如果你登陸YouPorn主頁(yè),它會(huì)悄悄用腳本檢查你訪問(wèn)過(guò)哪些色情網(wǎng)站。2010-12-12
JavaScript獲取當(dāng)前url根目錄(路徑)
本文主要介紹JavaScript獲取當(dāng)前url根目錄的方法,比較實(shí)用,需要的朋友可以參考一下。2016-06-06
小程序云開(kāi)發(fā)實(shí)現(xiàn)數(shù)據(jù)庫(kù)異步操作同步化
這篇文章主要為大家詳細(xì)介紹了小程序云開(kāi)發(fā)實(shí)現(xiàn)數(shù)據(jù)庫(kù)異步操作同步化,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05
js實(shí)現(xiàn)滑動(dòng)到頁(yè)面底部自動(dòng)加載更多功能
本文主要分享了js實(shí)現(xiàn)滑動(dòng)到頁(yè)面底部自動(dòng)加載更多功能的代碼。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02
你必須知道的Javascript知識(shí)點(diǎn)之"this指針"的應(yīng)用
本篇文章小編為大家介紹,你必須知道的Javascript知識(shí)點(diǎn)之"this指針"的應(yīng)用。需要的朋友參考下2013-04-04

