などのタグを指すわけではなく、属性、コメント、テキストなども含みます) を異なるノードとみなします。
ノード構造図
上の図は DOM CORE の構造図を示しています。より専門的なものを見てみましょう。
標準ブラウザでのこのコードの DOM パフォーマンスを見てみましょう。
div 要素と span 要素は、ノード構造図の Element 要素に対応する要素ノードとして表示されます。
"hello world" および div と div との間のスペーススパン 間隔は、ノード構造図の CharacterDate 要素
に対応するテキスト ノードとして表示されます。DOM CORE はドキュメントを解析するときに、すべての要素、属性、テキスト、コメントなどを 1 つのノードとして扱います。ノードオブジェクト (またはノードオブジェクトから継承されたオブジェクト、ポリモーフィック、上向き変換) がテキスト構造に従って順次表示され、最終的に「DOM ツリー」を形成します
DOM HTML の中心概念が HTMLElement の場合、DOM HTML はドキュメント内のすべての要素 (ここでの要素とは、特にコメント、属性、テキストを除く などのタグを指します) を HTMLElement として扱います。要素の属性は HTMLElement の属性です。
別の例を見てください:
ノード インターフェイスから提供される属性
myElement.attributes["id"].value; 明らかに myElement.attributes["id"] を返します。
Element によって実装されたメソッドは、現時点では明らかに id は単なる属性です。これは単なるプロパティを取得する操作です。
実際、DOM Core と DOM html の外部呼び出しインターフェイスには大きな違いはありません。HTML ドキュメントの場合は DOM html を使用して操作でき、xhtml の場合は DOM Core を使用できます。
BOM について
古いルール、最初に写真を撮りましょう: BOM はブラウザと緊密に統合されており、これらのオブジェクトも呼び出されるのはホスト オブジェクト、つまり環境によって提供されるオブジェクトです。
ここでは、グローバル オブジェクトを表す奇妙なオブジェクトを強調したいと思います。JavaScript では、追加の定義がなければ、独立した関数、変数、定数の存在は許可されず、それらはすべてプロパティまたはメソッドとして使用されます。 ParseInt()、isNaN()、isFinite() などのように、Nan、Infinity などの「定数」も Global オブジェクトの属性として扱います。 Boolean、String、Number、RegExp などの組み込みグローバル オブジェクトのコンストラクターも Global オブジェクトのプロパティですが、Global オブジェクトは実際には存在しません。つまり、Global.NaN を使用して NaN にアクセスすると、エラーが報告されます。実際、この役割を果たすのはウィンドウであり、このプロセスは JavaScript が最初に読み込まれるときに実行されます。
はい、わかりました、これで終わりです。元々は別の部分がありました。忘れてください。それについては後で別のセクションで説明します。