css3 - transition transform初始display:block怎么就沒移動效果?
問題描述
https://jsfiddle.net/zjmove/2...
---看完xiaoboost的回答---最后這樣改最合適:https://jsfiddle.net/25d3ga9j...我沒說清楚,其實我并不需要next的動畫,只需要left從右往左的效果。至于為什么初始display:block就沒有動畫效果,可能這樣初始item就已經(jīng)顯示出來了,force reflow沒來得及重繪;display:none就不需要重繪頁面了,left時直接從右往左就行了。再次感謝。
--只能說問題和這個force reflow有關,到底什么原理還是不清楚的。
--不同瀏覽器差異大啊上面的改法,在firefox里完美,在chrome57(ubuntu)里鼠標移動會閃動一次
--初始display:block,打印transforms屬性,發(fā)現(xiàn)force reflow并沒有生效。總結一下:display:block并且有過渡效果(transition)時就不生效。https://jsfiddle.net/25d3ga9j...
問題解答
回答1:首先,我個人覺得這是因為網(wǎng)頁渲染進程和js進程是互斥所導致的。
具體的可以看看這個問題:當我用js給元素添加className時,瀏覽器發(fā)生了什么? 我覺得高票答案已經(jīng)說的很清楚了,你在js腳本中加入的這么一句:
$(’.item’)[0].offsetWidth;
我猜也是想要強制重繪頁面吧?
我個人并沒有研究過這方面瀏覽器具體的實現(xiàn),但是根據(jù)我個人的觀察,讀取DOM的信息雖然會強制重繪網(wǎng)頁,但實際上也只是內(nèi)部數(shù)據(jù)的重新計算,DOM的改變并不會反映到頁面中,真正的頁面重繪還是只能等到當前js進程完成之后。
具體到你這個例子中,為了以示區(qū)別,我把.next和.left在css中的寬度稍微改了改,然后js中打印出添加上.next類之后的寬度:
.item.next { display: block; width: 50%; transform: translate3d(100%, 0, 0); left: 0;}.item.next.left { width: 100%; transform: translate3d(0, 0, 0); left: 0;}
$(’.item’).addClass(’next’);console.log($(’.item’)[0].offsetWidth); $(’.item’).addClass(’left’);
在這里你會看到,打印出來的寬度只有一半,說明在內(nèi)存中的DOM數(shù)據(jù)的確是已經(jīng)重新計算了,但是頁面卻并沒有重繪。 和那邊那個問題中的解決方案一樣,你也只能用異步函數(shù),在頁面效果切換的空隙中把進程空出來給頁面渲染,這樣你才能看到動態(tài)效果。
比如你這里,這么改就行了:
$(’.item’).addClass(’next’);setTimeout(() => { $(’.item’).addClass(’left’);}, 1000);
相關文章:
1. javascript - 在top.jsp點擊退出按鈕后,right.jsp進行頁面跳轉,跳轉到login.jsp2. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點3. java - spring-data Jpa 不需要執(zhí)行save 語句,Set字段就可以自動執(zhí)行保存的方法?求解4. css3 - 在sublime text里, 如何讓emmet生成的帶前綴css屬性垂直對齊?5. mac連接阿里云docker集群,已經(jīng)卡了2天了,求問?6. [前端求職必看]前端開發(fā)面試題與答案精選_擴展問題7. javascript - js 有什么優(yōu)雅的辦法實現(xiàn)在同時打開的兩個標簽頁間相互通信?8. javascript - jquery怎么給select option一個點擊時觸發(fā)的事件,如圖 如果選擇自定義觸發(fā)一個時間?9. css3 - Typecho 后臺部分表單按鈕在 Chrome 下出現(xiàn)靈異動畫問題,求解決10. html - CSS如何處理圖片縮放問題?
