現(xiàn)在手機的占比越來越高,各種酷炫頁面層出不窮唆鸡,這些特效都離不開css動畫涝影。說到css動畫,主流的情況也就無非這兩大類:位移和形變争占。
而我們在寫一個動畫特效的過程中燃逻,如何去提升它的性能呢?當(dāng)然首先我們需要去了解一下基本的概念臂痕,比如瀏覽器渲染的工作原理等伯襟,這些我也在讀了幾位大牛寫的相關(guān)文章后才有了一定的了解,這邊我也不細(xì)說了刻蟹,有興趣的同學(xué)可以去了解一下逗旁。
本次的目的簡單粗暴地講,其實就是我們應(yīng)該使用什么css屬性去進(jìn)行動畫的繪制時舆瘪,能夠有效的提高瀏覽器在渲染和繪制過程中的性能片效。
快速進(jìn)入主題,大家先來看個demo英古。我分別使用了left和transform在2秒內(nèi)向右平移了500px的位移淀衣。代碼如下:
然后在chrome下得到了如下的結(jié)果,第一張為使用left的截圖召调,第二張為使用transform的截圖:
顯而易見膨桥,我們在幀模式這里可以看到left比transform幀數(shù)要低,而且在渲染和繪制這邊的耗時唠叛,left要遠(yuǎn)遠(yuǎn)的大于transform只嚣。看到這里艺沼,相信大家心里已經(jīng)有結(jié)論了册舞。
我們再利用chrome的show paint rectangles來觀察一下兩者在動畫過程中,渲染和繪制的區(qū)域有何差異,第一張為使用left的截圖障般,第二張為使用transform的截圖:
怎么樣调鲸,看后是是否有收獲呀盛杰,希望小編的分享對大家有所幫助,也歡迎大家指出不足藐石,也可以加我Q群:142991222一起分享即供,這樣我們的友誼才能天長地久。
我們可以看到于微,使用left寫的整個動畫過程中逗嫡,瀏覽器一直在進(jìn)行繪制處理。而相對而言角雷,使用transform時祸穷,僅僅是在動畫開始和結(jié)束是進(jìn)行了繪制。因此勺三,對于動畫的性能上雷滚,transform要更為出色。至于原因吗坚,這里就要引入一個觸發(fā)重新布局的概念:
我們在改變一些屬性時祈远,如果是跟layout相關(guān)的屬性,則會觸發(fā)重新布局商源,導(dǎo)致渲染和繪制所需要的時間將會更長车份。因此,我們在寫動畫的時候因該規(guī)避這些屬性:width, height, margin, padding, border, display, top, right, bottom ,left, position, float, overflow等牡彻。
不會出發(fā)重新布局的屬性有:transform(其中的translate, rotate, scale), color, background等扫沼。
所以,我們平時在寫css動畫時庄吼,應(yīng)該優(yōu)先使用不觸發(fā)重新布局的屬性缎除,這樣可以使我們所展示動畫效果的更加流暢。