摘要:最近做了一個(gè)導(dǎo)航條動(dòng)畫,鼠標(biāo)的時(shí)候會(huì)有一個(gè)可移動(dòng)的下劃線,結(jié)構(gòu)大致如下使用了樣式在頁(yè)面生成的時(shí)候根據(jù)板塊不同需要初始化的位置。按理說(shuō)修改會(huì)導(dǎo)致頁(yè)面的重繪和回流,但是實(shí)際上卻沒(méi)有達(dá)到預(yù)想的效果。
最近做了一個(gè)導(dǎo)航條動(dòng)畫,鼠標(biāo)hover的時(shí)候會(huì)有一個(gè)可移動(dòng)的下劃線,html結(jié)構(gòu)大致如下
slider-underline使用了transition樣式:
.slider-underline { position: absolute; border-width: 1px 0; border-style: solid; border-color: #444; height: 0px; bottom: 12px; width: 26px; left : -26px; -webkit-transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); -moz-transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); -o-transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); }
在頁(yè)面生成的時(shí)候根據(jù)板塊不同需要初始化slider-underline的位置。
var underline_width = $(".slider-underline").width(); var active_position = $(".nav-sliderbar .actived").length ? $(".nav-sliderbar .actived").width()/2 + $(".nav-sliderbar .actived").position().left - underline_width/2 : - underline_width; //上面兩句是計(jì)算的導(dǎo)航條滑塊的初始的位置,正好在激活的板塊對(duì)應(yīng)位置的下方。 $(".slider-underline").css("left", active_position+"px");
由于slider-underline默認(rèn)有transition,因此在頁(yè)面刷新初始化其left位置的時(shí)候就會(huì)觸發(fā)動(dòng)畫效果。這個(gè)體驗(yàn)不是很好,希望能在初始化的時(shí)候不觸發(fā)這個(gè)動(dòng)畫,因此考慮了將動(dòng)畫效果做成一個(gè)類:
.underline-bezier { -webkit-transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); -moz-transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); -o-transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); transition: left 0.2s cubic-bezier(0.16, 0.71, 0.46, 1.43); }
js底下添加:
$(".slider-underline").css("left", active_position+"px"); $(".slider-underline").addClass("underline-bezier");
然而此處出現(xiàn)了問(wèn)題,這么做了頁(yè)面效果并沒(méi)有變化。
按理說(shuō)修改left會(huì)導(dǎo)致頁(yè)面的重繪和回流,但是實(shí)際上卻沒(méi)有達(dá)到預(yù)想的效果。
翻閱一些資料后,個(gè)人得出的結(jié)論是,瀏覽器為了減少重繪的次數(shù),會(huì)維護(hù)一個(gè)flush隊(duì)列,當(dāng)有需要重排的時(shí)候?qū)⒉僮鞣湃腙?duì)列,隊(duì)列滿時(shí)再一次性重繪。所以上面這兩句被瀏覽器合并到一起寫入了。
鑒于這個(gè)原因,我嘗試出了兩種解決辦法:
使用setTimeout
setTimeout(function() { $(".slider-underline").addClass("underline-bezier"); },0);
這個(gè)方法已開(kāi)始寫的時(shí)候只是嘗試性的,但是達(dá)到了需要的效果,具體原因究竟是因?yàn)闉g覽器任務(wù)插入的問(wèn)題還是因?yàn)閳?zhí)行其中函數(shù)前flush隊(duì)列已滿觸發(fā)了重繪,還真正沒(méi)有搞清楚。
強(qiáng)制提前flush隊(duì)列
當(dāng)獲取以下屬性的時(shí)候,瀏覽器為了獲取準(zhǔn)確的位置會(huì)強(qiáng)制瀏覽器提前flush隊(duì)列。
offsetTop, offsetLeft, offsetWidth, offsetHeight
scrollTop/Left/Width/Height
clientTop/Left/Width/Height
width,height
getComputedStyle() / currentStyle
因此將js改為:
$(".slider-underline").css("left", active_position+"px"); var get_left = $(".slider-underline").css("left"); $(".slider-underline").addClass("underline-bezier");
就能達(dá)到預(yù)想的效果了。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/111813.html
摘要:最近做了一個(gè)導(dǎo)航條動(dòng)畫,鼠標(biāo)的時(shí)候會(huì)有一個(gè)可移動(dòng)的下劃線,結(jié)構(gòu)大致如下使用了樣式在頁(yè)面生成的時(shí)候根據(jù)板塊不同需要初始化的位置。按理說(shuō)修改會(huì)導(dǎo)致頁(yè)面的重繪和回流,但是實(shí)際上卻沒(méi)有達(dá)到預(yù)想的效果。 最近做了一個(gè)導(dǎo)航條動(dòng)畫,鼠標(biāo)hover的時(shí)候會(huì)有一個(gè)可移動(dòng)的下劃線,html結(jié)構(gòu)大致如下 AAA BBB CCC DD...
摘要:瀏覽器渲染樹(shù)我們假設(shè)響應(yīng)后和文件已經(jīng)齊備了,此時(shí)瀏覽器會(huì)怎么做呢當(dāng)前響應(yīng)瀏覽器的普適渲染方式首先,瀏覽器會(huì)根據(jù)文件生成樹(shù),載入文件構(gòu)建。 showImg(https://segmentfault.com/img/bVKUyX?w=630&h=292); 瀏覽器渲染樹(shù) 我們假設(shè)HTTP響應(yīng)后HTML和CSS、JavaScript文件已經(jīng)齊備了,此時(shí)瀏覽器會(huì)怎么做呢?當(dāng)前HTTP響應(yīng)瀏覽器...
摘要:瀏覽器渲染樹(shù)我們假設(shè)響應(yīng)后和文件已經(jīng)齊備了,此時(shí)瀏覽器會(huì)怎么做呢當(dāng)前響應(yīng)瀏覽器的普適渲染方式首先,瀏覽器會(huì)根據(jù)文件生成樹(shù),載入文件構(gòu)建。 showImg(https://segmentfault.com/img/bVKUyX?w=630&h=292); 瀏覽器渲染樹(shù) 我們假設(shè)HTTP響應(yīng)后HTML和CSS、JavaScript文件已經(jīng)齊備了,此時(shí)瀏覽器會(huì)怎么做呢?當(dāng)前HTTP響應(yīng)瀏覽器...
摘要:瀏覽器渲染樹(shù)我們假設(shè)響應(yīng)后和文件已經(jīng)齊備了,此時(shí)瀏覽器會(huì)怎么做呢當(dāng)前響應(yīng)瀏覽器的普適渲染方式首先,瀏覽器會(huì)根據(jù)文件生成樹(shù),載入文件構(gòu)建。 showImg(https://segmentfault.com/img/bVKUyX?w=630&h=292); 瀏覽器渲染樹(shù) 我們假設(shè)HTTP響應(yīng)后HTML和CSS、JavaScript文件已經(jīng)齊備了,此時(shí)瀏覽器會(huì)怎么做呢?當(dāng)前HTTP響應(yīng)瀏覽器...
摘要:對(duì)于復(fù)雜動(dòng)畫效果使用絕對(duì)定位讓其脫離文檔流對(duì)于復(fù)雜動(dòng)畫效果,由于會(huì)經(jīng)常的引起回流重繪,因此,我們可以使用絕對(duì)定位,讓它脫離文檔流。硬件加速加速比起考慮如何減少回流重繪,我們更期望的是,根本不要回流重繪。 回流和重繪可以說(shuō)是每一個(gè)web開(kāi)發(fā)者都經(jīng)常聽(tīng)到的兩個(gè)詞語(yǔ),我也不例外,可是我之前一直不是很清楚這兩步具體做了什么事情。最近由于部門內(nèi)部要做分享,所以對(duì)其進(jìn)行了一些研究,看了一些博客和書...
閱讀 1216·2021-09-30 09:47
閱讀 3768·2021-09-06 15:02
閱讀 1781·2021-09-01 10:46
閱讀 2363·2019-08-30 15:52
閱讀 600·2019-08-29 15:28
閱讀 1874·2019-08-29 15:08
閱讀 1154·2019-08-29 13:28
閱讀 2580·2019-08-29 12:19