欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解小程序BackgroundAudioManager踩坑之旅

 更新時(shí)間:2019年12月08日 08:28:47   作者:打代碼的橘子  
這篇文章主要介紹了詳解小程序BackgroundAudioManager踩坑之旅,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

由于貴公司業(yè)務(wù)發(fā)展需要,切圖仔開始寫起了小程序啦(興奮地搓小手手)

貴公司是知識(shí)付費(fèi)平臺(tái),需要音頻播放課程,同時(shí)希望用戶在退出小程序后依然可以聽課。在這種情況下,小程序的API——BackgroundAudioManager就派得上用場啦。

在看完官方文檔,信心滿滿地寫完提測后,測試小姐姐找出的bug比我的工資還多?。。?#128557;😭😭)因此有了本篇文章。

本篇涉及到的幾個(gè)坑(以下BAM為BackgroundAudioManager的縮寫)

  • 一個(gè)誤區(qū)
  • BAM.onStop() 與 BAM.onEnded() 的坑
  • BAM.seek() 與 BAM.onSeeked() 的坑
  • BAM.onTimeUpdate() 的坑
  • 在音頻頁退出小程序暫停音頻后返回小程序的坑

一個(gè)誤區(qū)

  • BAM.onCanplay()是監(jiān)聽背景音頻進(jìn)入可播放狀態(tài)事件,并不代表在該事件中,音頻就為播放狀態(tài)。

BAM.onStop() 與 BAM.onEnded() 的坑

在BAM.onStop() 與 BAM.onEnded()的回調(diào)事件中,audio.src為空

BAM.onStop(): 當(dāng)再次播放音頻時(shí),將data數(shù)據(jù)中音頻的src賦值給BAM,然后在onTimeUpdate()事件內(nèi)跳轉(zhuǎn)到上次暫停的時(shí)間點(diǎn)(記得本地緩存音頻播放時(shí)間哦~)

BAM.onEnded():在BAM.onEnded()回調(diào)函數(shù)中,將data數(shù)據(jù)中音頻的src賦值給BAM,然后在onTimeUpdate()事件內(nèi)暫停音頻

BAM.seek() 與 BAM.onSeeked() 的坑

  • 設(shè)置src后立即seek()失效

seek操作最好放在BAM.onTimeUpdate事件中。 類似HTML的Audio元素的ontimeupdate方法,建議將currentTime的改變都在該方法中進(jìn)行。

  • 暫停狀態(tài)下跳轉(zhuǎn)到指定位置,在onSeeked()回調(diào)中,Android的currentTime是跳轉(zhuǎn)前的時(shí)間,而IOS是跳轉(zhuǎn)后的時(shí)間

雖然在onSeeked()回調(diào)函數(shù)中,Android獲取currentTime為跳轉(zhuǎn)前的時(shí)間,但若開始播放,還是從指定位置開始播放。所以若有暫停連續(xù)跳轉(zhuǎn)并需要獲取currentTime的需求,可在onSeeked()回調(diào)函數(shù)中判斷若為Android并且為暫停狀態(tài)時(shí)播放。

  • 開發(fā)者工具不走onSeeked()回調(diào)

如果在onSeeked()回調(diào)里面有特殊操作,記得區(qū)分是否是開發(fā)者工具~

BAM.onTimeUpdate() 的坑

在退出小程序后,Android與IOS均不走onTimeUpdate()事件

因此若在onTimeUpdate()事件內(nèi)實(shí)時(shí)緩存音頻的播放時(shí)長會(huì)導(dǎo)致在退出小程序暫停后返回拿到的音頻緩存時(shí)間是退出前的時(shí)間。可以在onPause()與onEnded()事件中記錄暫停時(shí)的音頻播放時(shí)長。(在onTimeUpdate()事件內(nèi)所做的操作可根據(jù)實(shí)際情況考慮節(jié)流哦~)

在音頻頁退出小程序暫停音頻后返回小程序的坑

IOS:BAM.src為空

Android:BAM.src不為空,但play()失敗

這點(diǎn)與第二點(diǎn)的處理方式相同。當(dāng)在音頻頁退出小程序暫停音頻后返回,進(jìn)入onShow()事件時(shí),將data數(shù)據(jù)中音頻的src賦值給BAM,然后在onTimeUpdate()事件內(nèi)跳轉(zhuǎn)到上次暫停的時(shí)間點(diǎn)

原本以為可以寫的會(huì)有很多,最后寫下來也就幾個(gè)點(diǎn),表達(dá)的不也是很清晰,就當(dāng)學(xué)習(xí)日記吧

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • js實(shí)現(xiàn)非常棒的彈出div

    js實(shí)現(xiàn)非常棒的彈出div

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)非常棒的彈出div,具有一定的參考價(jià)值,感興趣的朋友可以參考一下
    2016-10-10
  • 一文全面解析JS中的this綁定規(guī)則

    一文全面解析JS中的this綁定規(guī)則

    寫過JavaScript的都知道,JS中的this相對來講是比較難以捉摸的,尤其在一些復(fù)雜的場景下的指向總是讓人摸不著頭腦,所以這篇文章我們就來系統(tǒng)的學(xué)習(xí)和研究一下this的綁定規(guī)則,需要的朋友可以參考下
    2024-04-04
  • JS實(shí)現(xiàn)簡易留言板特效

    JS實(shí)現(xiàn)簡易留言板特效

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡易留言板特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • Base64編碼加密JS代碼網(wǎng)頁版

    Base64編碼加密JS代碼網(wǎng)頁版

    Base64編碼加密JS代碼網(wǎng)頁版,在文本框中輸入任意字符串,即可將該字符串按Base64編碼進(jìn)行加密,也可將任意Base64編碼的字符解密顯示正常值
    2013-03-03
  • js調(diào)用設(shè)備攝像頭的方法

    js調(diào)用設(shè)備攝像頭的方法

    這篇文章主要為大家詳細(xì)介紹了js調(diào)用設(shè)備攝像頭的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • javascript實(shí)用小函數(shù)使用介紹

    javascript實(shí)用小函數(shù)使用介紹

    本文整理了一些實(shí)用小函數(shù)如阻止輸入非數(shù)字,backspace除外;限制輸入最大字符串長度等,需要的朋友可以了解下
    2013-11-11
  • JavaScript事件學(xué)習(xí)小結(jié)(三)js事件對象

    JavaScript事件學(xué)習(xí)小結(jié)(三)js事件對象

    這篇文章主要介紹了JavaScript事件學(xué)習(xí)小結(jié)(三)js事件對象的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • LBS blog sql注射漏洞[All version]-官方已有補(bǔ)丁

    LBS blog sql注射漏洞[All version]-官方已有補(bǔ)丁

    LBS blog sql注射漏洞[All version]-官方已有補(bǔ)丁...
    2007-08-08
  • js實(shí)現(xiàn)二級聯(lián)動(dòng)簡單實(shí)例

    js實(shí)現(xiàn)二級聯(lián)動(dòng)簡單實(shí)例

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)二級聯(lián)動(dòng)簡單實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • JavaScript制作簡易計(jì)算器(不用eval)

    JavaScript制作簡易計(jì)算器(不用eval)

    這篇文章主要為大家詳細(xì)介紹了JavaScript制作簡易計(jì)算器的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02

最新評論