亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

css3 - transition transform初始display:block怎么就沒移動效果?

瀏覽:152日期:2023-06-21 17:36:51

問題描述

https://jsfiddle.net/zjmove/2...

---看完xiaoboost的回答---最后這樣改最合適:https://jsfiddle.net/25d3ga9j...我沒說清楚,其實我并不需要next的動畫,只需要left從右往左的效果。至于為什么初始display:block就沒有動畫效果,可能這樣初始item就已經顯示出來了,force reflow沒來得及重繪;display:none就不需要重繪頁面了,left時直接從右往左就行了。再次感謝。

--只能說問題和這個force reflow有關,到底什么原理還是不清楚的。

--不同瀏覽器差異大啊上面的改法,在firefox里完美,在chrome57(ubuntu)里鼠標移動會閃動一次

--初始display:block,打印transforms屬性,發現force reflow并沒有生效。總結一下:display:block并且有過渡效果(transition)時就不生效。https://jsfiddle.net/25d3ga9j...

問題解答

回答1:

首先,我個人覺得這是因為網頁渲染進程和js進程是互斥所導致的。

具體的可以看看這個問題:當我用js給元素添加className時,瀏覽器發生了什么? 我覺得高票答案已經說的很清楚了,你在js腳本中加入的這么一句:

$(’.item’)[0].offsetWidth;

我猜也是想要強制重繪頁面吧?

我個人并沒有研究過這方面瀏覽器具體的實現,但是根據我個人的觀察,讀取DOM的信息雖然會強制重繪網頁,但實際上也只是內部數據的重新計算,DOM的改變并不會反映到頁面中,真正的頁面重繪還是只能等到當前js進程完成之后。

具體到你這個例子中,為了以示區別,我把.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’);

在這里你會看到,打印出來的寬度只有一半,說明在內存中的DOM數據的確是已經重新計算了,但是頁面卻并沒有重繪。 和那邊那個問題中的解決方案一樣,你也只能用異步函數,在頁面效果切換的空隙中把進程空出來給頁面渲染,這樣你才能看到動態效果。

比如你這里,這么改就行了:

$(’.item’).addClass(’next’);setTimeout(() => { $(’.item’).addClass(’left’);}, 1000);

標簽: CSS
相關文章:
主站蜘蛛池模板: 亚洲高清免费视频 | 自偷自拍三级全三级视频 | 亚洲人人精品 | 日韩一级a毛片欧美区 | 国产精品9999久久久久 | 91短视频在线观看手机 | 美国a级作爱片免费观看美国 | 亚洲成a人片在线观看www | 欧美日韩一区二区三区色综合 | 亚洲国产精品综合久久2007 | 热久久伊人 | 亚洲精品啪啪一区二区三区 | 黄网站在线观看永久免费 | 成人免费视频网 | 自拍视频国产 | 日本免费的一级绿象 | 亚洲欧美久久一区二区 | 成人欧美一区二区三区 | 亚洲免费区 | 91频视| 免费日韩精品 | 成人久久精品一区二区三区 | 好吊色综合网天天高清 | 成人精品视频网站 | 亚洲精品久久久久网站 | 222www免费观看 | 韩国黄色毛片 | 国产成人一区二区三区影院免费 | 国产欧美一区视频在线观看 | 久久国产精品亚洲一区二区 | 国产精品yjizz视频网一二区 | 国产一级视频在线观看网站 | 国产黄色a级 | 久久久精彩视频 | 久青草视频97国内免费影视 | 2020国产成人精品免费视频 | 国产成人免费片在线观看 | 大片在线播放日本一级毛片 | 免费大片黄在线观看日本 | 综合久久综合 | 国产免费福利 |