摘要:會(huì)存在過度繪制,會(huì)造成幀丟失,繼而導(dǎo)致動(dòng)畫斷續(xù)顯示。瀏覽器可以優(yōu)化并行的動(dòng)畫動(dòng)作,更合理的重新排列動(dòng)作序列,并把能夠合并的動(dòng)作放在一個(gè)渲染周期內(nèi)完成,從而呈現(xiàn)出更流暢的動(dòng)畫效果。通過,動(dòng)畫能夠和動(dòng)畫變換或動(dòng)畫同步發(fā)生。
就終極目的來說,requestAnimationFrame就是setTimeout。既然有了setTimeout,那還要requestAnimationFrame來干嘛。setTimeout會(huì)存在過度繪制,會(huì)造成幀丟失,繼而導(dǎo)致動(dòng)畫斷續(xù)顯示。這也是setTimeout的定時(shí)器值推薦最小使用16.7ms的原因(16.7 = 1000 / 60, 即每秒60幀)。
瀏覽器可以優(yōu)化并行的動(dòng)畫動(dòng)作,更合理的重新排列動(dòng)作序列,并把能夠合并的動(dòng)作放在一個(gè)渲染周期內(nèi)完成,從而呈現(xiàn)出更流暢的動(dòng)畫效果。requestAnimationFrame就是為了這個(gè)而出現(xiàn)的。我所做的事情很簡(jiǎn)單,跟著瀏覽器的繪制走,如果瀏覽設(shè)備繪制間隔是16.7ms,那我就這個(gè)間隔繪制;如果瀏覽設(shè)備繪制間隔是10ms, 我就10ms繪制。這樣就不會(huì)存在過度繪制的問題,動(dòng)畫不會(huì)掉幀。通過requestAnimationFrame(),JS動(dòng)畫能夠和CSS動(dòng)畫/變換或SVG SMIL動(dòng)畫同步發(fā)生。另外,如果在一個(gè)瀏覽器標(biāo)簽頁里運(yùn)行一個(gè)動(dòng)畫,當(dāng)這個(gè)標(biāo)簽頁不可見時(shí),瀏覽器會(huì)暫停它,這會(huì)減少CPU,內(nèi)存的壓力,節(jié)省電池電量。
requestAnimationFrame的用法為了更好的兼容各種瀏覽器,加上了兼容各種瀏覽器引擎前綴。谷歌瀏覽器,火狐瀏覽器,IE10+都實(shí)現(xiàn)了這個(gè)函數(shù),即使在ie9以下,執(zhí)行requestAnimationFrame方法也不會(huì)出錯(cuò)。
(function() { var lastTime = 0; var vendors = ["webkit", "moz"]; for(var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) { window.requestAnimationFrame = window[vendors[x] + "RequestAnimationFrame"]; window.cancelAnimationFrame = window[vendors[x] + "CancelAnimationFrame"] || // name has changed in Webkit window[vendors[x] + "CancelRequestAnimationFrame"]; } if (!window.requestAnimationFrame) { window.requestAnimationFrame = function(callback, element) { var currTime = new Date().getTime(); var timeToCall = Math.max(0, 16.7 - (currTime - lastTime)); var id = window.setTimeout(function() { callback(currTime + timeToCall); }, timeToCall); lastTime = currTime + timeToCall; return id; }; } if (!window.cancelAnimationFrame) { window.cancelAnimationFrame = function(id) { clearTimeout(id); }; } }()); window.requestAnimationFrame(function(/* time */ time){ // time ~= +new Date // the unix time });
參考文章
http://www.zhangxinxu.com/wor...
http://www.webhek.com/request...
http://blog.chinaunix.net/uid...
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/86760.html
摘要:會(huì)存在過度繪制,會(huì)造成幀丟失,繼而導(dǎo)致動(dòng)畫斷續(xù)顯示。瀏覽器可以優(yōu)化并行的動(dòng)畫動(dòng)作,更合理的重新排列動(dòng)作序列,并把能夠合并的動(dòng)作放在一個(gè)渲染周期內(nèi)完成,從而呈現(xiàn)出更流暢的動(dòng)畫效果。通過,動(dòng)畫能夠和動(dòng)畫變換或動(dòng)畫同步發(fā)生。 就終極目的來說,requestAnimationFrame就是setTimeout。既然有了setTimeout,那還要requestAnimationFrame來干嘛...
摘要:會(huì)存在過度繪制,會(huì)造成幀丟失,繼而導(dǎo)致動(dòng)畫斷續(xù)顯示。瀏覽器可以優(yōu)化并行的動(dòng)畫動(dòng)作,更合理的重新排列動(dòng)作序列,并把能夠合并的動(dòng)作放在一個(gè)渲染周期內(nèi)完成,從而呈現(xiàn)出更流暢的動(dòng)畫效果。通過,動(dòng)畫能夠和動(dòng)畫變換或動(dòng)畫同步發(fā)生。 就終極目的來說,requestAnimationFrame就是setTimeout。既然有了setTimeout,那還要requestAnimationFrame來干嘛...
摘要:會(huì)存在過度繪制,會(huì)造成幀丟失,繼而導(dǎo)致動(dòng)畫斷續(xù)顯示。瀏覽器可以優(yōu)化并行的動(dòng)畫動(dòng)作,更合理的重新排列動(dòng)作序列,并把能夠合并的動(dòng)作放在一個(gè)渲染周期內(nèi)完成,從而呈現(xiàn)出更流暢的動(dòng)畫效果。通過,動(dòng)畫能夠和動(dòng)畫變換或動(dòng)畫同步發(fā)生。 就終極目的來說,requestAnimationFrame就是setTimeout。既然有了setTimeout,那還要requestAnimationFrame來干嘛...
摘要:無線頁面本就分秒必爭(zhēng),更不用說當(dāng)我們?cè)跓o線頁面中使用動(dòng)畫的時(shí)候。頁面中元素的布局是相對(duì)的,因此一個(gè)元素的布局發(fā)生變化,會(huì)聯(lián)動(dòng)地引發(fā)其他元素的布局發(fā)生變化。它通知瀏覽器在頁面重繪前執(zhí)行你的回調(diào)函數(shù)。 無線頁面本就分秒必爭(zhēng),更不用說當(dāng)我們?cè)跓o線頁面中使用動(dòng)畫的時(shí)候。不管是css動(dòng)畫還是canvas動(dòng)畫,我們都需要時(shí)刻小心著,并且有必要掌握頁面性能的基本分析方法。 既然我們的目標(biāo)是優(yōu)化,那么...
閱讀 1639·2021-11-25 09:43
閱讀 2546·2019-08-30 15:54
閱讀 3015·2019-08-30 15:53
閱讀 1156·2019-08-30 15:53
閱讀 799·2019-08-30 15:52
閱讀 2593·2019-08-26 13:36
閱讀 869·2019-08-26 12:16
閱讀 1289·2019-08-26 12:13