CSS 過渡不適用於最初隱藏的元素
當元素最初使用CSS 的顯示隱藏時:無,任何應用於該元素的CSS 過渡當其可見性改變時不會觸發。這是因為 CSS 轉換依賴於元素的初始計算樣式,對於隱藏元素,該樣式將為空。
CSSOM 與 DOM
要了解此行為,區分 CSS 物件模型 (CSSOM) 和文件物件模型 (DOM) 很重要。 DOM 表示 HTML 文件的層次結構,而 CSSOM 包含每個元素的計算樣式。
回流和繪製
當元素的可見性為更改後,瀏覽器需要更新 CSSOM 並重排頁面以反映變更。回流會根據元素的 CSS 規則重新計算元素的計算樣式和位置。繪製是在螢幕上渲染頁面的過程,發生在重排之後。
過渡啟動
CSS 過渡透過在元素的初始計算樣式與其元素之間進行插值來工作最終風格。當元素最初隱藏時,其計算樣式將為空,因此轉換演算法無法建立初始狀態。
解決方案:強制回流
來觸發轉換對於隱藏元素,需要在更改其可見性後強制回流。這可以使用 requestAnimationFrame API 來實現,該 API 在瀏覽器繪製頁面之前執行回呼。
透過使用 requestAnimationFrame,可以在瀏覽器更新 CSSOM 後套用 CSS 過渡,從而允許過渡正確啟動。
範例
這是程式碼的修改版本使用requestAnimationFrame 強制回流:
$('button').on('click', function() { $('.b').show(); requestAnimationFrame(() => { document.body.offsetHeight; // Force a reflow $('.b').css('right', '80%'); // Trigger the transition $('.a').css('right', '80%'); }); });
總之,CSS 過渡不適用於最初隱藏的元素,因為CSSOM 不包含它們的初始計算樣式。要觸發轉換,需要在更改元素的可見性後強制回流。
以上是為什麼 CSS 過渡對最初隱藏的元素不起作用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Wufoo一直在集成方面非常出色。他們與特定應用程序(例如廣告系列顯示器,MailChimp和Typekit)進行集成,但他們也


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SublimeText3 Linux新版
SublimeText3 Linux最新版

WebStorm Mac版
好用的JavaScript開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。