首頁  >  文章  >  web前端  >  如何在沒有框架的情況下確定 DOM 準備?

如何在沒有框架的情況下確定 DOM 準備?

Patricia Arquette
Patricia Arquette原創
2024-10-20 10:27:02539瀏覽

How to Determine DOM Readiness without Frameworks?

在沒有框架的情況下了解DOM 準備

開發Web 應用程式時,確定文件物件模型(DOM) 何時準備好進行操作至關重要。雖然像 jQuery 這樣的框架提供了 readyState 偵聽器,但本文探討了偵測 DOM 就緒情況的替代方法。

直接存取DOM 狀態

您可以直接存取DOM 狀態,而不是依賴框架檢查文件的readyState屬性:

<code class="js">if (document.readyState === 'complete') {
  // DOM is ready
}</code>

但是,這種方法在瀏覽器中並不可靠,因為有些瀏覽器可能無法提供準確的readyState值。

基於事件的DOM就緒檢查

更跨瀏覽器的方法是監聽DOMContentLoaded 事件,該事件在DOM 準備好進行操作時觸發:

<code class="js">function fireOnReady() {
  // ...
}
if (document.readyState === 'complete') {
  fireOnReady();
} else {
  document.addEventListener("DOMContentLoaded", fireOnReady);
}</code>

利用jQuery 未記錄的isReady 屬性

雖然沒有文件記錄,但jQuery 公開了一個isReady 屬性,該屬性在內部指示DOM 就緒狀態:

<code class="js">if ($.isReady) {
  // DOM is ready
} else {
  // DOM is not yet ready
}</code>

輕量級DOM Ready 程式碼片段

受Dustin Diaz 程式碼片段的啟發,您可以建立一個迷你DOM 就緒偵聽器,如下所示:

<code class="js">if (!/in/.test(document.readyState)) {
  // Document is ready
} else {
  // Document is not ready
}</code>

此檢查利用了ReadyState 值在早期載入狀態中包含「in」的事實,使其成為可靠的指示器DOM 準備就緒。

以上是如何在沒有框架的情況下確定 DOM 準備?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn