發(fā)生在支付寶小程序中的一個bug
這段時間,開發(fā)支付寶小程序,遇到一個只會發(fā)生在ios系統(tǒng)上的問題。
問題
page頁:等待頁面 (輪調(diào)接口查詢結(jié)果) 成功跳轉(zhuǎn)到支付成功頁面。
當把小程序隱藏,例如,關(guān)閉屏幕,之后再進入
問題來了,在支付成功頁面 會不斷 輪調(diào) 之前等待頁面 的接口。
即便退出小程序,依舊會在支付寶后臺輪調(diào)。
考慮的原因
- 定時器關(guān)閉的問題。
- app.js的onShow 拿到了輪調(diào)的方法。
定時器。
- 檢查了定時器。從局部的定義的timer 。設(shè)置成全局的timer ,并在頁面卸載的時候,clearInterval 。 問題依舊會重現(xiàn)。
- 將定時器設(shè)置成globalData。之后在頁面卸載的時候清除,并在支付成功頁面 onLoad方法里卸載。問題依舊會重現(xiàn)
排除了定時器的問題,那么就是app.js的onShow問題了。
app.js的onShow方法
onShow() {
let that = this;
that.getStorageInfo();
app.globalData.waitingcardtimer = setInterval(()=>{
that.getPayResult()
},3000)
},
將onShow的代碼清空,方法寫在 onLoad()里。
onLoad() {
let that = this;
that.getStorageInfo();
app.globalData.waitingcardtimer = setInterval(()=>{
that.getPayResult()
},3000)
},
問題可能產(chǎn)生的原因,我估計是因為,小程序在判斷哪個onShow 的時候有自己的標識,但是在定時器的影響下。由于小程序退出后臺,定時器還在執(zhí)行。這時候,小程序的onShow默認這個方法是自己的方法。這時候。拿到了輪調(diào)的方法。從而去操作。