JavaScript の DOM と BOM の概要

不言
不言転載
2018-11-20 14:53:572437ブラウズ

この記事では、JavaScript の DOM と BOM について説明します。必要な方は参考にしてください。

ドキュメント オブジェクト モデル (DOM)

インタビュアーは「ドキュメント オブジェクト モデルとは何か知っていますか?」と尋ねるのが好きです。そこで、今日はそれを 1 つずつ説明します。

##DOM:Document Object Model

Document

中国語訳: ドキュメント。ここでのドキュメントとは、ページを作成するときの XML および HTML ページを指します。これを Web ブラウザにロードすると、DOM がバックグラウンドで静かに生成され、作成した Web ページのドキュメントがドキュメント オブジェクトに変換されます。

オブジェクト

中国語訳: オブジェクト。JS を勉強する学生は、JavaScript の「すべてがオブジェクトである」という文に精通している必要があります。言語の種類は、次の 3 つのタイプに大別できます。

ユーザー定義オブジェクト
    自作オブジェクト (例:
  • var obj = {}

    #)
    ##組み込みオブジェクト

    JavaScript に組み込まれたオブジェクトは、当社が作成する必要はなく、配列、数学、データなど、直接使用できます。

  • ホスト オブジェクト

    前回では、環境をホストした後、ホスト オブジェクトとは何かを理解したはずです。ここでは、ウィンドウやドキュメントなど、ブラウザによって提供されるオブジェクトについて説明します。

  • DOM における主な関心事はドキュメントです。ドキュメント オブジェクトの主な機能は、Web ページのコンテンツを処理することです。

Model

中国語翻訳: モデル、この単語を DOM から抽出すると、下の図を見てください ~ 理解しやすいでしょう。 たとえば、図に示すように、これは一連のコミュニティ構築モデルです。基本的に、住宅を購入する人は、この一連のモデルに従うだけで理解できます。建設が完了した後のコミュニティの長さはどのようになるか、公共施設はどのくらいあるのか、植生面積はどれくらいか...

DOM もこのようなモデルのようなものですが、それを表します。現在の Web ページがブラウザ ウィンドウに読み込まれ、JavaScript を使用してそれを操作して読み取ることができます。

モデルを取得したら、そのモデルを理解できるようにする必要もあります (これは、このモデルが何に使用されるかを知る必要があるため理解できます)。モデルを理解するのは、人と話しているようなものです。盲人は、太陽が見えないため、概念がありません。ただし、DOM は読めます。 JavaScript を使用する場合、まずモデルを理解できる必要があります。

DOM はドキュメントを 1 つの主要な枝と無数の枝からなるツリーとして表します。実際、私は個人的には家系図に似ていると考えています。タグ間の関係を説明するとき、並列タグと入れ子のタグを示すために「親」、「子」、「兄弟」などの単語をよく使用するためです。

たとえば、次の図:

具体的なコードは次のとおりです:

<!DOCTYPE html> <html>
<head>
<meta charset="UTF-8">

<title>Document</title>
</head>
<body>
<h1>Hello World!</h1>

<p>欢迎观看本次文章,包含以下内容:</p>

<ul>

    <li>ECMAScript</li>

    <li>DOM</li>

    <li>BOM</li>

</ul>
</body>
</html>

抽象化します上記の構造を DOM ツリーに変換します。

JavaScript の DOM と BOM の概要

上の図から、ルート要素が html であり、2 つのサブ要素があることがはっきりとわかります。以下の要素、1 つはヘッド、もう 1 つはボディ、ヘッドとボディの関係は兄弟などです。このようにして、モデルを使用してページ内のすべての要素をツリーに抽象化できます。

つまり、DOM は単に、ドキュメントのコンテンツを抽象化して概念化し、Web コンテンツにアクセスして操作するためのメソッドとインターフェイスを提供するメソッドのセットです。

JavaScript の DOM と BOM の概要DOM のレベル

ECMAScript だけにバージョンがあるとは考えないでください。DOM にもさまざまなレベルがあります。

W3C 公式 Web サイト:

https://www.w3.org/standards/...DOM は次のように分かれています:

DOM0: 組み込み基準はありません。主に画像の反転やフォームデータの検証に使用されます。

DOM1: 1998 年 10 月に策定された標準。DOM コアと DOM HTML の 2 つの部分で構成されます。

  • DOM2: マウスとユーザー インターフェイスのイベント、範囲、トラバーサルが拡張され、CSS のサポートが追加されました。

  • DOM3: DOM がさらに拡張され、ドキュメントを検証する新しい方法が追加され、XML 1.0 仕様がサポートされています。

  • Web ブラウザによる DOM のサポート
  • レベルがあるため、互換性の問題に直面することは避けられません。次に、DOM のブラウザ サポートを見てみましょう。各バージョン:

画像は「JavaScript Advanced Programming」から引用

実際、DOM は JavaScript だけでなく、他の多くの言語でも使用できます。すべて DOM を実装

ブラウザ オブジェクト モデル (BOM)JavaScript の DOM と BOM の概要

BOM: ブラウザ オブジェクト モデル

ブラウザと対話するためのメソッドとインターフェイスを提供します。

DOM を理解して BOM を見れば、それほど詳しい説明は必要ありません。開発者は、BOM を使用して、現在のブラウザのバージョンを取得するなど、ブラウザで表示されるページ以外の部分を制御できます。

基本的に、BOM はブラウザのウィンドウとフレームのみを扱いますが、人々はブラウザのすべての JavaScript 拡張機能を BOM の一部としてカウントすることに慣れています。そのような拡張機能をいくつか紹介します。

  • #新しいブラウザ ウィンドウをポップアップする機能

  • #ブラウザ ウィンドウを移動、ズーム、閉じる機能

  • ブラウザに関する詳細情報を提供するナビゲータ オブジェクト

  • ブラウザによって読み込まれたページに関する詳細情報を提供するロケーション オブジェクト

  • #ユーザーのモニター解像度に関する詳細情報を提供する画面オブジェクト

  • Cookie のサポート

  • Like XMLHttpRequest と IE の ActiveXObject カスタム オブジェクト

BOM には標準がないため、各ブラウザには独自の実装があります。

しかし、すべての主要なブラウザには共通のオブジェクトがあるため、これらのオブジェクトは事実上の標準になっています。

W3C は、ブラウザーでの JavaScript の最も基本的な部分を標準化し、BOM の主要な側面を HTML5 仕様に組み込みました。

以上がJavaScript の DOM と BOM の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はsegmentfault.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。