requestAnimationFrame使用示例詳解
requestAnimationFrame--use是什么
告訴瀏覽器用來執(zhí)行一個動畫,并且在下一次重繪之前調(diào)用其指定的回調(diào)函數(shù)取更新動畫,所以該方法的參數(shù)就是一個回調(diào)函數(shù),在下一次重繪時候調(diào)用。
回調(diào)函數(shù)
回調(diào)函數(shù)即是傳入的callback,執(zhí)行后其傳入的參數(shù)為DOMhighResTimeStamp,表示當(dāng)前回調(diào)函數(shù)執(zhí)行時時間戳,單位毫秒。
調(diào)用頻率
其回調(diào)函數(shù)執(zhí)行次數(shù)為每秒60次,為啥是這個呢,因為在大多數(shù)瀏覽器種,這個頻率大多都跟屏幕幀數(shù)刷新頻率保持一致,即在高刷新的屏幕中會執(zhí)行的更快。
返回啥
返回的是一個非零整數(shù)值,作為唯一標識,傳給window.cancelAnimationFrame(),可用來清除取消回調(diào)函數(shù)。
如何用window.requestAnimationFrame(callback);
示例

可以看到瀏覽器在一直打印,這也就是類似動畫的持續(xù)過程,一秒鐘會輸出60次。
那怎樣讓其停止,除了使用window.cancelAnimationFrame();官方指出了為了提高性能和電池壽命,當(dāng)requestAnimationFrame()運行在后臺標簽頁或者隱藏的iframe里,就會被暫停調(diào)用以提升性能。
多個運行情況
當(dāng)一個頁面有多個requestAnimationFrame時,運行情況又是怎樣的呢

執(zhí)行調(diào)試輸出內(nèi)容為

可以看出再同一毫秒時刻,兩個方法會同步執(zhí)行,可見并不存在先后的情況,其每次執(zhí)行隔間時間戳近似等于 1000 / 60 = 16.666毫秒,這就意味頁面加載一次,會一次性執(zhí)行所有的requestAnimationFrame。
停止執(zhí)行
cancelAnimationFrame

動畫運用

效果如下圖

總結(jié)
requestAnimationFrame是瀏覽器的一個宏任務(wù),其用法也跟setTimeOut很相似,其執(zhí)行的步驟是根據(jù)瀏覽器的繪制頻率來的,采用系統(tǒng)的刷新間隔時間,可以保證在繪制的一次過程中只執(zhí)行一次,確保了性能,不會出現(xiàn)卡頓和掉幀的情況,這樣就確保了動畫加載的流暢,同時也降低了cpu的消耗和內(nèi)存占用,是canvas動畫里面最常用的一種api。
以上就是requestAnimationFrame使用示例詳解的詳細內(nèi)容,更多關(guān)于requestAnimationFrame使用的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JQ中$(window).load和$(document).ready區(qū)別與執(zhí)行順序
JQ中的$(document).ready()大家應(yīng)該用的非常多,基本每個JS腳本中都有這個函數(shù)的出現(xiàn)有時甚至?xí)霈F(xiàn)多個,那么另一個加載函數(shù)$(window).load相對出現(xiàn)的次數(shù)就很少了,下面為大家介紹一下兩者的區(qū)別與他們的執(zhí)行順序2017-03-03
JavaScript?CSS優(yōu)雅實現(xiàn)網(wǎng)頁多主題風(fēng)格換膚功能詳解
這篇文章主要為大家介紹了JavaScript?CSS優(yōu)雅的實現(xiàn)網(wǎng)頁多主題風(fēng)格換膚功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02
微信小程序上滑加載下拉刷新(onscrollLower)分批加載數(shù)據(jù)(二)
這篇文章主要介紹了微信小程序上滑加載下拉刷新(onscrollLower)分批加載數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2017-05-05
Dom-api MutationObserver使用方法詳解
這篇文章主要為大家介紹了Dom-api MutationObserver使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
微信小程序-getUserInfo回調(diào)的實例詳解
這篇文章主要介紹了微信小程序-getUserInfo回調(diào)的實例詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下2017-10-10

