ホームページ > ウェブフロントエンド > jsチュートリアル > フレームワークを使用せずに DOM の準備が整っているかどうかを判断するにはどうすればよいですか?

フレームワークを使用せずに DOM の準備が整っているかどうかを判断するにはどうすればよいですか?

Patricia Arquette
リリース: 2024-10-20 10:27:02
オリジナル
675 人が閲覧しました

How to Determine DOM Readiness without Frameworks?

フレームワークを使用しない DOM の準備状況を理解する

Web アプリケーションを開発する場合、ドキュメント オブジェクト モデル (DOM) がいつ操作できる状態になっているかを判断することが重要です。 jQuery などのフレームワークは readyState リスナーを提供しますが、この記事では、DOM の準備状況を検出するための別のアプローチを検討します。

DOM 状態への直接アクセス

フレームワークに依存する代わりに、直接アクセスできます。ドキュメントの sreadyState プロパティを確認します:

<code class="js">if (document.readyState === 'complete') {
  // DOM is ready
}</code>
ログイン後にコピー

ただし、一部のブラウザでは正確な readyState 値が提供されない可能性があるため、このアプローチはブラウザ間で信頼できません。

イベントベースの DOM Ready Check

よりクロスブラウザなアプローチは、DOM の操作の準備ができたときに発生する DOMContentLoaded イベントをリッスンすることです。

<code class="js">function fireOnReady() {
  // ...
}
if (document.readyState === 'complete') {
  fireOnReady();
} else {
  document.addEventListener("DOMContentLoaded", fireOnReady);
}</code>
ログイン後にコピー

jQuery の文書化されていない isReady プロパティを利用する

文書化されていませんが、jQuery は DOM の準備完了状態を内部的に示す isReady プロパティを公開しています:

<code class="js">if ($.isReady) {
  // DOM is ready
} else {
  // DOM is not yet ready
}</code>
ログイン後にコピー

Lightweight DOM Ready Snippet

Dustin Diaz のスニペットにヒントを得て、次のようにミニ DOM Ready リスナーを作成できます。

<code class="js">if (!/in/.test(document.readyState)) {
  // Document is ready
} else {
  // Document is not ready
}</code>
ログイン後にコピー

このチェックは、readyState 値に以前の読み込み状態で「in」が含まれているという事実を活用し、信頼できるインジケーターとします。 DOM の準備ができています。

以上がフレームワークを使用せずに DOM の準備が整っているかどうかを判断するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート