JS 倒計時問題,手機網(wǎng)頁后臺運行時,js會暫停。但是時間還在走,當(dāng)用戶返回主界面的時候倒計時就不準(zhǔn)了。這個有什么辦法解決嗎
你這個問題可以試一下用這個 js 來嘗試:https://github.com/leeenx/tim...
使用 timer.setTimeout
& timer.setInterval
替代原生的 setTimeout
& setInterval
試一下。具體的 API 如下: https://github.com/leeenx/tim...
這個 timer 是用 RAF 模擬的。當(dāng) js 掛起時,它也會掛起。
使用JS計時確實會存現(xiàn)這種問題,js腳本在瀏覽器出處后臺情況時是全部暫停執(zhí)行的,有些瀏覽器在tab切換也會暫停,包括setInterval
和webworker
不管是同步還是異步,那么解決方案也有很多種,需要根據(jù)你的實際項目情況來定
比如一個很簡單的30秒倒計時任務(wù),后臺js停止執(zhí)行,但系統(tǒng)時間是不會停止的。建議使用系統(tǒng)時間做比對,簡碼如下
let st = Date.now(),
i = 0,
itv = setInterval(()=>{
i = ~~((Date.now() - st)/1000);
if(i >= 3){
clearInterval(itv)
alert('time over')
}
},1000);
有個visibilitychange事件,瀏覽器標(biāo)簽頁被隱藏或顯示的時候會觸發(fā).隱藏時記錄時間戳,顯示時記錄時間戳,求二者之差/1000得到離開時間。
這是我的想法,沒測試過,不知道能否成功,只是一個建議,你可以試一試
var start,end,s;
document.addEventListener('webkitvisibilitychange', function () {
if (document.webkitVisibilityState == 'hidden') {
start = new Date().getTime();
} else {
end = new Date().getTime();
s = ((end-start)/1000); //為秒
}
});
document.addEventListener('mozvisibilitychange',function() {
if (document.mozVisibilityState == 'hidden') {
start = new Date().getTime();
} else {
end = new Date().getTime();
s = ((end-start)/1000);
}
});
當(dāng)然只是倒計時的話你可以判斷visibilityState =='visible'里面重新獲取時間戳,重啟倒計時
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團,成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負責(zé)iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。