XMLDOM-クイックガイド
ザ・ D文書 Object Model(DOM)はW3C標準です。HTMLやXMLなどのドキュメントにアクセスするための標準を定義します。
W3Cによって設定されたDOMの定義は次のとおりです。
ドキュメントオブジェクトモデル(DOM)は、HTMLおよびXMLドキュメント用のアプリケーションプログラミングインターフェイス(API)です。これは、ドキュメントの論理構造と、ドキュメントへのアクセスおよび操作の方法を定義します。
DOMは、すべてのXML要素にアクセスするためのオブジェクトとプロパティおよびメソッド(インターフェイス)を定義します。それは3つの異なる部分/レベルに分かれています-
Core DOM −構造化されたドキュメントの標準モデル
XML DOM −XMLドキュメントの標準モデル
HTML DOM −HTMLドキュメントの標準モデル
XML DOMは、XMLの標準オブジェクトモデルです。XMLドキュメントには、ノードと呼ばれる情報単位の階層があります。DOMは、これらのノードとノード間の関係を記述するための標準的なプログラミングインターフェイスです。
XML DOMは、開発者がアプリケーションを作成するためにツリー上の任意のポイントでノードを追加、編集、移動、または削除できるようにするAPIも提供します。
以下は、DOM構造の図です。この図は、パーサーが各ノードをトラバースすることにより、XMLドキュメントをDOM構造として評価することを示しています。
XMLDOMの利点
XMLDOMの利点は次のとおりです。
XML DOMは、言語とプラットフォームに依存しません。
XMLDOMは traversable -XML DOMの情報は階層に編成されているため、開発者は階層内を移動して特定の情報を探すことができます。
XMLDOMは modifiable -それは本質的に動的であり、開発者にツリー上の任意のポイントでノードを追加、編集、移動、または削除するためのスコープを提供します。
XMLDOMのデメリット
一度書き込まれたプログラムは、明示的に削除されるまで常にメモリに残るため、(XML構造が大きい場合)より多くのメモリを消費します。
メモリの使用量が多いため、SAXと比較して動作速度は遅くなります。
DOMの意味がわかったので、DOM構造とは何かを見てみましょう。DOMドキュメントは、階層に編成されたノードまたは情報のコレクションです。一部のタイプのノードが持っていることがあり、子、様々なタイプのノードを、他の文書構造でそれらの下に何かを持つことができないリーフノードです。以下は、ノードタイプのリストと、子として持つ可能性のあるノードタイプのリストです。
Document −要素(最大1)、ProcessingInstruction、Comment、DocumentType(最大1)
DocumentFragment −要素、ProcessingInstruction、Comment、Text、CDATASection、EntityReference
EntityReference −要素、ProcessingInstruction、Comment、Text、CDATASection、EntityReference
Element −要素、テキスト、コメント、ProcessingInstruction、CDATASection、EntityReference
Attr −テキスト、EntityReference
ProcessingInstruction −子供はいない
Comment −子供はいない
Text −子供はいない
CDATASection −子供はいない
Entity −要素、ProcessingInstruction、Comment、Text、CDATASection、EntityReference
Notation −子供はいない
例
次のXMLドキュメントのDOM表現を検討してください node.xml。
<?xml version = "1.0"?>
<Company>
<Employee category = "technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
</Employee>
<Employee category = "non-technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
</Employee>
</Company>
上記のXMLドキュメントのドキュメントオブジェクトモデルは次のようになります-
上記のフローチャートから、次のように推測できます。
ノードオブジェクトは、親ノードオブジェクトを1つだけ持つことができます。これは、すべてのノードの上の位置を占めます。こちらが会社です。
親ノードは、と呼ばれる複数のノード持つことができ、子ノードを。これらの子ノードには、属性ノードと呼ばれる追加のノードを含めることができます。上記の例では、TechnicalとNon-technicalの2つの属性ノードがあります。属性ノードは、実際には要素ノードの子ではありませんが、まだそれに関連付けられています。
これらの子ノードは、複数の子ノードを持つことができます。ノード内のテキストは、テキストノードと呼ばれます。
同じレベルのノードオブジェクトは兄弟と呼ばれます。
DOMは-を識別します
インターフェイスを表し、ドキュメントを操作するためのオブジェクト。
オブジェクトとインターフェイス間の関係。
この章では、XMLDOMノードについて学習します。すべてのXMLDOMには、ノードと呼ばれる階層単位の情報が含まれており、DOMはこれらのノードとそれらの間の関係を記述します。
ノードタイプ
次のフローチャートは、すべてのノードタイプを示しています-
XMLで最も一般的なタイプのノードは次のとおりです。
Document Node−完全なXMLドキュメント構造はドキュメントノードです。
Element Node−すべてのXML要素は要素ノードです。これは、属性を持つことができる唯一のタイプのノードでもあります。
Attribute Node−各属性は属性ノードと見なされます。要素ノードに関する情報が含まれていますが、実際には要素の子とは見なされません。
Text Node−ドキュメントテキストはテキストノードと見なされます。より多くの情報または空白だけで構成できます。
あまり一般的ではないタイプのノードは次のとおりです。
CData Node−このノードには、パーサーによって分析されるべきではない情報が含まれています。代わりに、プレーンテキストとして渡す必要があります。
Comment Node −このノードにはデータに関する情報が含まれており、通常、アプリケーションによって無視されます。
Processing Instructions Node −このノードには、特にアプリケーションを対象とした情報が含まれています。
Document Fragments Node
Entities Node
Entity reference nodes
Notations Node
この章では、XMLDOMノードツリーについて学習します。XMLドキュメントでは、情報は階層構造で維持されます。この階層構造はノードツリーと呼ばれます。この階層により、開発者は特定の情報を探してツリー内を移動できるため、ノードにアクセスできます。その後、これらのノードのコンテンツを更新できます。
ノードツリーの構造は、ルート要素から始まり、最下位レベルまで子要素に広がります。
例
次の例は、ノードツリーが構造である単純なXMLドキュメントを次の図に示しています。
<?xml version = "1.0"?>
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
</Employee>
</Company>
上記の例に見られるように、(そのDOMの)画像表現は以下のようになります-
ツリーの最上位ノードは、 root。ザ・rootノードは<Company>であり、<Company>には<Employee>の2つのノードが含まれています。これらのノードは子ノードと呼ばれます。
ルートノード<Company>の子ノード<Employee>は、それ自体の子ノード(<FirstName>、<LastName>、<ContactNo>)で構成されます。
2つの子ノード<Employee>には、属性値TechnicalとNon-Technicalがあり、属性ノードと呼ばれます。
すべてのノード内のテキストは、テキストノードと呼ばれます。
XMLDOM-メソッド
APIとしてのDOMには、要素やテキストなど、XMLドキュメントに含まれるさまざまな種類の情報を表すインターフェイスが含まれています。これらのインターフェイスには、これらのオブジェクトを操作するために必要なメソッドとプロパティが含まれています。プロパティはノードの特性を定義しますが、メソッドはノードを操作する方法を提供します。
次の表に、DOMクラスとインターフェイスを示します-
S.No. | インターフェースと説明 |
---|---|
1 | DOMImplementation これは、ドキュメントオブジェクトモデルの特定のインスタンスに依存しない操作を実行するためのいくつかのメソッドを提供します。 |
2 | DocumentFragment これは「軽量」または「最小」のドキュメントオブジェクトであり、(Documentのスーパークラスとして)XML / HTMLツリーを本格的なドキュメントに固定します。 |
3 | Document これは、XMLドキュメントの最上位ノードを表し、ルート要素を含むドキュメント内のすべてのノードへのアクセスを提供します。 |
4 | Node XMLノードを表します。 |
5 | NodeList これは、ノードオブジェクトの読み取り専用リストを表します。 |
6 | NamedNodeMap 名前でアクセスできるノードのコレクションを表します。 |
7 | Data DOM内の文字データにアクセスするための一連の属性とメソッドでNodeを拡張します。 |
8 | Attribute Elementオブジェクトの属性を表します。 |
9 | Element 要素ノードを表します。ノードから派生します。 |
10 | Text テキストノードを表します。CharacterDataから派生します。 |
11 | Comment コメントノードを表します。CharacterDataから派生します。 |
12 | ProcessingInstruction これは「処理命令」を表します。これは、ドキュメントのテキストにプロセッサ固有の情報を保持する方法としてXMLで使用されます。 |
13 | CDATA Section これはCDATAセクションを表します。テキストから派生。 |
14 | Entity エンティティを表します。ノードから派生します。 |
15 | EntityReference これは、ツリー内のエンティティ参照を表します。ノードから派生します。 |
上記の各インターフェイスのメソッドとプロパティについては、それぞれの章で説明します。
この章では、XMLのロードと解析について学習します。
APIによって提供されるインターフェースを記述するために、W3Cはインターフェース定義言語(IDL)と呼ばれる抽象言語を使用します。IDLを使用する利点は、開発者が自分の好きな言語でDOMを使用する方法を学び、別の言語に簡単に切り替えることができることです。
欠点は、抽象的であるため、IDLをWeb開発者が直接使用できないことです。プログラミング言語の違いにより、抽象インターフェースと具体的な言語の間にマッピング(またはバインディング)が必要です。DOMは、Javascript、JScript、Java、C、C ++、PLSQL、Python、Perlなどのプログラミング言語にマッピングされています。
次のセクションと章では、XMLファイルをロードするためのプログラミング言語としてJavascriptを使用します。
パーサー
パーサは、我々の場合のXML文書で、文書を分析し、情報を何か特定を行うために設計されたソフトウェアアプリケーションです。DOMベースのパーサーの一部を次の表に示します-
S.No | パーサーと説明 |
---|---|
1 | JAXP SunMicrosystemのXML解析用JavaAPI(JAXP) |
2 | XML4J IBMのJava用XMLパーサー(XML4J) |
3 | msxml MicrosoftのXMLパーサー(msxml)バージョン2.0は、Internet Explorer5.5に組み込まれています。 |
4 | 4DOM 4DOMはPythonプログラミング言語のパーサーです |
5 | XML::DOM XML :: DOMは、Perlを使用してXMLドキュメントを操作するためのPerlモジュールです。 |
6 | Xerces ApacheのXercesJavaパーサー |
DOMのようなツリーベースのAPIでは、パーサーはXMLファイルをトラバースし、対応するDOMオブジェクトを作成します。次に、DOM構造を前後にトラバースできます。
XMLのロードと解析
XMLドキュメントのロード中、XMLコンテンツは2つの形式で提供されます-
- XMLファイルとして直接
- XML文字列として
XMLファイルとしてのコンテンツ
次の例は、XMLコンテンツがXMLファイルとして受信されたときに、AjaxとJavascriptを使用してXML(node.xml)データをロードする方法を示しています。ここで、Ajax関数はxmlファイルのコンテンツを取得し、それをXMLDOMに格納します。DOMオブジェクトが作成されると、それが解析されます。
<!DOCTYPE html>
<html>
<body>
<div>
<b>FirstName:</b> <span id = "FirstName"></span><br>
<b>LastName:</b> <span id = "LastName"></span><br>
<b>ContactNo:</b> <span id = "ContactNo"></span><br>
<b>Email:</b> <span id = "Email"></span>
</div>
<script>
//if browser supports XMLHttpRequest
if (window.XMLHttpRequest) { // Create an instance of XMLHttpRequest object.
code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp = new XMLHttpRequest();
} else { // code for IE6, IE5
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
// sets and sends the request for calling "node.xml"
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
// sets and returns the content as XML DOM
xmlDoc = xmlhttp.responseXML;
//parsing the DOM object
document.getElementById("FirstName").innerHTML =
xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0].nodeValue;
document.getElementById("LastName").innerHTML =
xmlDoc.getElementsByTagName("LastName")[0].childNodes[0].nodeValue;
document.getElementById("ContactNo").innerHTML =
xmlDoc.getElementsByTagName("ContactNo")[0].childNodes[0].nodeValue;
document.getElementById("Email").innerHTML =
xmlDoc.getElementsByTagName("Email")[0].childNodes[0].nodeValue;
</script>
</body>
</html>
node.xml
<Company>
<Employee category = "Technical" id = "firstelement">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
コードの詳細のほとんどはスクリプトコードにあります。
Internet ExplorerはActiveXObject( "Microsoft.XMLHTTP")を使用してXMLHttpRequestオブジェクトのインスタンスを作成し、他のブラウザーはXMLHttpRequest()メソッドを使用します。
responseXMLは、 XML DOMに直接XMLコンテンツを変換します。
XMLコンテンツがJavaScriptXML DOMに変換されると、JSDOMメソッドとプロパティを使用して任意のXML要素にアクセスできます。childNodes、nodeValueなどのDOMプロパティと、getElementsById(ID)、getElementsByTagName(tags_name)などのDOMメソッドを使用しました。
実行
このファイルをloadingexample.htmlとして保存し、ブラウザで開きます。次の出力が表示されます-
XML文字列としてのコンテンツ
次の例は、XMLコンテンツがXMLファイルとして受信されたときにAjaxとJavascriptを使用してXMLデータをロードする方法を示しています。ここで、Ajax関数は、xmlファイルのコンテンツを取得し、それをXMLDOMに格納します。DOMオブジェクトが作成されると、それが解析されます。
<!DOCTYPE html>
<html>
<head>
<script>
// loads the xml string in a dom object
function loadXMLString(t) { // for non IE browsers
if (window.DOMParser) {
// create an instance for xml dom object parser = new DOMParser();
xmlDoc = parser.parseFromString(t,"text/xml");
}
// code for IE
else { // create an instance for xml dom object
xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.async = false;
xmlDoc.loadXML(t);
}
return xmlDoc;
}
</script>
</head>
<body>
<script>
// a variable with the string
var text = "<Employee>";
text = text+"<FirstName>Tanmay</FirstName>";
text = text+"<LastName>Patil</LastName>";
text = text+"<ContactNo>1234567890</ContactNo>";
text = text+"<Email>[email protected]</Email>";
text = text+"</Employee>";
// calls the loadXMLString() with "text" function and store the xml dom in a variable
var xmlDoc = loadXMLString(text);
//parsing the DOM object
y = xmlDoc.documentElement.childNodes;
for (i = 0;i<y.length;i++) {
document.write(y[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
コードの詳細のほとんどはスクリプトコードにあります。
Internet ExplorerはActiveXObject( "Microsoft.XMLDOM")を使用してXMLデータをDOMオブジェクトにロードし、他のブラウザーはDOMParser()関数とparseFromString(text、 'text / xml')メソッドを使用します。
変数textには、XMLコンテンツを含む文字列が含まれている必要があります。
XMLコンテンツがJavaScriptXML DOMに変換されると、JSDOMメソッドとプロパティを使用して任意のXML要素にアクセスできます。childNodes、nodeValueなどのDOMプロパティを使用しました。
実行
このファイルをloadingexample.htmlとして保存し、ブラウザで開きます。次の出力が表示されます-
XMLコンテンツがJavaScriptXML DOMにどのように変換されるかを確認したので、XMLDOMメソッドを使用して任意のXML要素にアクセスできるようになりました。
この章では、XMLDOMトラバーシングについて説明します。前の章で、XMLドキュメントをロードし、取得したDOMオブジェクトを解析する方法を学習しました。この解析されたDOMオブジェクトはトラバースできます。トラバースは、ノードツリー内のすべての要素を段階的に移動することにより、体系的な方法でループが実行されるプロセスです。
例
次の例(traverse_example.htm)は、DOMトラバースを示しています。ここでは、<Employee>要素の各子ノードをトラバースします。
<!DOCTYPE html>
<html>
<style>
table,th,td {
border:1px solid black;
border-collapse:collapse
}
</style>
<body>
<div id = "ajax_xml"></div>
<script>
//if browser supports XMLHttpRequest
if (window.XMLHttpRequest) {// Create an instance of XMLHttpRequest object.
code for IE7+, Firefox, Chrome, Opera, Safari
var xmlhttp = new XMLHttpRequest();
} else {// code for IE6, IE5
var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
// sets and sends the request for calling "node.xml"
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
// sets and returns the content as XML DOM
var xml_dom = xmlhttp.responseXML;
// this variable stores the code of the html table
var html_tab = '<table id = "id_tabel" align = "center">
<tr>
<th>Employee Category</th>
<th>FirstName</th>
<th>LastName</th>
<th>ContactNo</th>
<th>Email</th>
</tr>';
var arr_employees = xml_dom.getElementsByTagName("Employee");
// traverses the "arr_employees" array
for(var i = 0; i<arr_employees.length; i++) {
var employee_cat = arr_employees[i].getAttribute('category');
// gets the value of 'category' element of current "Element" tag
// gets the value of first child-node of 'FirstName'
// element of current "Employee" tag
var employee_firstName =
arr_employees[i].getElementsByTagName('FirstName')[0].childNodes[0].nodeValue;
// gets the value of first child-node of 'LastName'
// element of current "Employee" tag
var employee_lastName =
arr_employees[i].getElementsByTagName('LastName')[0].childNodes[0].nodeValue;
// gets the value of first child-node of 'ContactNo'
// element of current "Employee" tag
var employee_contactno =
arr_employees[i].getElementsByTagName('ContactNo')[0].childNodes[0].nodeValue;
// gets the value of first child-node of 'Email'
// element of current "Employee" tag
var employee_email =
arr_employees[i].getElementsByTagName('Email')[0].childNodes[0].nodeValue;
// adds the values in the html table
html_tab += '<tr>
<td>'+ employee_cat+ '</td>
<td>'+ employee_firstName+ '</td>
<td>'+ employee_lastName+ '</td>
<td>'+ employee_contactno+ '</td>
<td>'+ employee_email+ '</td>
</tr>';
}
html_tab += '</table>';
// adds the html table in a html tag, with id = "ajax_xml"
document.getElementById('ajax_xml').innerHTML = html_tab;
</script>
</body>
</html>
このコードはnode.xmlをロードします。
XMLコンテンツはJavaScriptXMLDOMオブジェクトに変換されます。
getElementsByTagName()メソッドを使用した要素の配列(タグElementを含む)が取得されます。
次に、この配列をトラバースして、子ノードの値をテーブルに表示します。
実行
このファイルをサーバーパスにtraverse_example.htmlとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。次の出力が表示されます-
これまで、DOM構造、XML DOMオブジェクトをロードして解析する方法、およびDOMオブジェクトをトラバースする方法について学習しました。ここでは、DOMオブジェクト内のノード間を移動する方法を説明します。XML DOMは、ノードをナビゲートするのに役立つノードのさまざまなプロパティで構成されています。
- parentNode
- childNodes
- firstChild
- lastChild
- nextSibling
- previousSibling
以下は、他のノードとの関係を示すノードツリーの図です。
DOM-親ノード
このプロパティは、親ノードをノードオブジェクトとして指定します。
例
次の例(navigate_example.htm)は、XMLドキュメント(node.xml)をXMLDOMオブジェクトに解析します。次に、DOMオブジェクトは子ノードを介して親ノードにナビゲートされます-
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
var y = xmlDoc.getElementsByTagName("Employee")[0];
document.write(y.parentNode.nodeName);
</script>
</body>
</html>
上記の例でわかるように、子ノードEmployeeはその親ノードに移動します。
実行
このファイルをnavigate_example.htmlとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、Employeeの親ノード、つまりCompanyを取得します。
第一子
このプロパティはNode型であり、NodeListに存在する最初の子名を表します。
例
次の例(first_node_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析してから、DOMオブジェクトに存在する最初の子ノードに移動します。
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_firstChild(p) {
a = p.firstChild;
while (a.nodeType != 1) {
a = a.nextSibling;
}
return a;
}
var firstchild = get_firstChild(xmlDoc.getElementsByTagName("Employee")[0]);
document.write(firstchild.nodeName);
</script>
</body>
</html>
関数get_firstChild(p)は、空のノードを回避するために使用されます。ノードリストからfirstChild要素を取得するのに役立ちます。
x = get_firstChild(xmlDoc.getElementsByTagName("Employee")[0])タグ名Employeeの最初の子ノードをフェッチします。
実行
このファイルをfirst_node_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、我々は最初の子ノードを取得従業員つまり姓を。
最後の子
このプロパティはNode型であり、NodeListに存在する最後の子名を表します。
例
次の例(last_node_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析してから、xmlDOMオブジェクトに存在する最後の子ノードに移動します。
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_lastChild(p) {
a = p.lastChild;
while (a.nodeType != 1){
a = a.previousSibling;
}
return a;
}
var lastchild = get_lastChild(xmlDoc.getElementsByTagName("Employee")[0]);
document.write(lastchild.nodeName);
</script>
</body>
</html>
実行
このファイルをサーバーパスにlast_node_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、Employeeの最後の子ノード、つまりEmailを取得します。
次の兄弟
このプロパティはNode型であり、次の子、つまりNodeListに存在する指定された子要素の次の兄弟を表します。
例
次の例(nextSibling_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析します。このオブジェクトは、xmlドキュメントに存在する次のノードにすぐに移動します。
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
}
else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_nextSibling(p) {
a = p.nextSibling;
while (a.nodeType != 1) {
a = a.nextSibling;
}
return a;
}
var nextsibling = get_nextSibling(xmlDoc.getElementsByTagName("FirstName")[0]);
document.write(nextsibling.nodeName);
</script>
</body>
</html>
実行
このファイルをnextSibling_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、FirstNameの次の兄弟ノード、つまりLastNameを取得します。
前の兄弟
このプロパティはNode型であり、前の子、つまりNodeListに存在する指定された子要素の前の兄弟を表します。
例
次の例(previoussibling_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析してから、xmlドキュメントに存在する最後の子ノードのbeforeノードをナビゲートします。
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest)
{
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_previousSibling(p) {
a = p.previousSibling;
while (a.nodeType != 1) {
a = a.previousSibling;
}
return a;
}
prevsibling = get_previousSibling(xmlDoc.getElementsByTagName("Email")[0]);
document.write(prevsibling.nodeName);
</script>
</body>
</html>
実行
このファイルをprevioussibling_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、Eメールの前の兄弟ノード、つまりContactNoを取得します。
この章では、XMLドキュメントの情報単位と見なされるXMLDOMノードにアクセスする方法について学習します。XML DOMのノード構造により、開発者はツリー内を移動して特定の情報を探し、同時にその情報にアクセスできます。
ノードへのアクセス
以下は、ノードにアクセスするための3つの方法です-
を使用して getElementsByTagName () 方法
ノードツリーをループまたはトラバースする
ノード関係を使用して、ノードツリーをナビゲートする
getElementsByTagName()
この方法では、ノード名を指定することでノードの情報にアクセスできます。また、ノードリストとノードリストの長さの情報にアクセスすることもできます。
構文
getElementByTagName()メソッドの構文は次のとおりです。
node.getElementByTagName("tagname");
どこ、
node-はドキュメントノードです。
tagname-値を取得するノードの名前を保持します。
例
以下は、メソッドgetElementByTagNameの使用法を示す簡単なプログラムです。
<!DOCTYPE html>
<html>
<body>
<div>
<b>FirstName:</b> <span id = "FirstName"></span><br>
<b>LastName:</b> <span id = "LastName"></span><br>
<b>Category:</b> <span id = "Employee"></span><br>
</div>
<script>
if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp = new XMLHttpRequest();
} else {// code for IE6, IE5
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
document.getElementById("FirstName").innerHTML =
xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0].nodeValue;
document.getElementById("LastName").innerHTML =
xmlDoc.getElementsByTagName("LastName")[0].childNodes[0].nodeValue;
document.getElementById("Employee").innerHTML =
xmlDoc.getElementsByTagName("Employee")[0].attributes[0].nodeValue;
</script>
</body>
</html>
上記の例では、ノードFirstName、LastName、およびEmployeeの情報にアクセスしています。
xmlDoc.getElementsByTagName( "FirstName")[0] .childNodes [0] .nodeValue; この行は、getElementByTagName()メソッドを使用して子ノードFirstNameの値にアクセスします。
xmlDoc.getElementsByTagName( "Employee")[0] .attributes [0] .nodeValue; この行は、ノードのEmployee getElementByTagName()メソッドの属性値にアクセスします。
ノードをトラバースする
これについては、「DOMトラバース」の章で例を挙げて説明しています。
ノードをナビゲートする
これについては、「DOMナビゲーション」の章で例を挙げて説明しています。
この章では、XMLDOMオブジェクトのノード値を取得する方法について学習します。XMLドキュメントには、ノードと呼ばれる情報単位の階層があります。Nodeオブジェクトには、要素の値を返すプロパティnodeValueがあります。
次のセクションでは、-について説明します。
要素のノード値を取得する
ノードの属性値を取得する
node.xml以下のすべての実施例において使用は以下の通りであります-
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
ノード値を取得する
getElementsByTagName()メソッドは、指定されたタグ名を持つすべての要素のNodeListをドキュメント順に返します。
例
次の例(getnode_example.htm)は、XML文書(構文解析node.xmlをXML DOMオブジェクトに)、子ノードのノード値を抽出ファーストネーム(0のインデックス) -
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else{
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
x = xmlDoc.getElementsByTagName('FirstName')[0]
y = x.childNodes[0];
document.write(y.nodeValue);
</script>
</body>
</html>
実行
このファイルをgetnode_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、ノード値をTanmayとして取得します。
属性値を取得する
属性はXMLノード要素の一部です。ノード要素は、複数の一意の属性を持つことができます。属性は、XMLノード要素に関する詳細情報を提供します。より正確には、ノード要素のプロパティを定義します。XML属性は、常に名前と値のペアです。この属性の値は、属性ノードと呼ばれます。
getAttribute()メソッドは、要素名を指定して属性値を取得します。
例
次の例(get_attribute_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、カテゴリEmployee(インデックス2)の属性値を抽出します。
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
x = xmlDoc.getElementsByTagName('Employee')[2];
document.write(x.getAttribute('category'));
</script>
</body>
</html>
実行
このファイルをサーバーパスにget_attribute_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、属性値をManagementとして取得します。
この章では、XMLDOMオブジェクトのノードの値を変更する方法について学習します。ノード値は次のように変更できます-
var value = node.nodeValue;
場合は、ノードがある属性その後、値の変数は、属性の値になります。場合は、ノードがあるテキストノードは、テキストコンテンツとなります。場合は、ノードがある要素にはなりヌル。
次のセクションでは、各ノードタイプ(属性、テキストノード、および要素)のノード値設定について説明します。
node.xml以下のすべての実施例において使用は以下の通りであります-
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
テキストノードの値を変更する
Node要素の値の変更とは、要素のテキストコンテンツ(テキストノードとも呼ばれます)を編集することを意味します。次の例は、要素のテキストノードを変更する方法を示しています。
例
次の例(set_text_node_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、要素のテキストノードの値を変更します。この場合、各従業員の電子メールを[email protected]に送信し、値を印刷します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("Email");
for(i = 0;i<x.length;i++) {
x[i].childNodes[0].nodeValue = "[email protected]";
document.write(i+');
document.write(x[i].childNodes[0].nodeValue);
document.write('<br>');
}
</script>
</body>
</html>
実行
このファイルをサーバーパスにset_text_node_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。次の出力が表示されます-
0) [email protected]
1) [email protected]
2) [email protected]
属性ノードの値を変更する
次の例は、要素の属性ノードを変更する方法を示しています。
例
次の例(set_attribute_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、要素の属性ノードの値を変更します。この場合、カテゴリ毎の従業員に管理-0、管理-1、管理-2は、それぞれと値を出力。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("Employee");
for(i = 0 ;i<x.length;i++){
newcategory = x[i].getAttributeNode('category');
newcategory.nodeValue = "admin-"+i;
document.write(i+');
document.write(x[i].getAttributeNode('category').nodeValue);
document.write('<br>');
}
</script>
</body>
</html>
実行
このファイルをサーバーパスにset_node_attribute_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。結果は以下のようになります-
0) admin-0
1) admin-1
2) admin-2
この章では、ドキュメントオブジェクトのいくつかのメソッドを使用して新しいノードを作成する方法について説明します。これらのメソッドは、新しい要素ノード、テキストノード、コメントノード、CDATAセクションノード、および属性ノードを作成するためのスコープを提供します。新しく作成されたノードが要素オブジェクトにすでに存在する場合は、新しいノードに置き換えられます。次のセクションでは、これを例とともに示します。
新しい要素ノードを作成します
createElement()メソッドは、新しい要素ノードを作成します。新しく作成された要素ノードが要素オブジェクトに存在する場合、それは新しいノードに置き換えられます。
構文
createElement()メソッドを使用するための構文は次のとおりです。
var_name = xmldoc.createElement("tagname");
どこ、
var_name-は、新しい要素の名前を保持するユーザー定義の変数名です。
( "tagname") -作成される新しい要素ノードの名前です。
例
次の例(createnewelement_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、XMLドキュメントに新しい要素ノードPhoneNoを作成します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
new_element = xmlDoc.createElement("PhoneNo");
x = xmlDoc.getElementsByTagName("FirstName")[0];
x.appendChild(new_element);
document.write(x.getElementsByTagName("PhoneNo")[0].nodeName);
</script>
</body>
</html>
new_element = xmlDoc.createElement( "PhoneNo"); 新しい要素ノード<PhoneNo>を作成します
x.appendChild(new_element); xは、新しい要素ノードが追加される、指定された子ノード<FirstName>の名前を保持します。
実行
このファイルをcreatenewelement_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、属性値をPhoneNoとして取得します。
新しいテキストノードを作成する
createTextNode()メソッドは、新しいテキストノードを作成します。
構文
createTextNode()を使用する構文は次のとおりです-
var_name = xmldoc.createTextNode("tagname");
どこ、
var_name-新しいテキストノードの名前を保持するユーザー定義の変数名です。
( "tagname") -括弧内は、作成される新しいテキストノードの名前です。
例
次の例(createtextnode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、XMLドキュメントに新しいテキストノードIm新しいテキストノードを作成します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_e = xmlDoc.createElement("PhoneNo");
create_t = xmlDoc.createTextNode("Im new text node");
create_e.appendChild(create_t);
x = xmlDoc.getElementsByTagName("Employee")[0];
x.appendChild(create_e);
document.write(" PhoneNO: ");
document.write(x.getElementsByTagName("PhoneNo")[0].childNodes[0].nodeValue);
</script>
</body>
</html>
上記のコードの詳細は以下のとおりです-
create_e = xmlDoc.createElement( "PhoneNo"); 新しい要素< PhoneNo >を作成します。
create_t = xmlDoc.createTextNode( "Im new text node"); 新しいテキストノード「Imnewtextnode」を作成します。
x.appendChild(create_e); テキストノード、「イム新しいテキストノードは」 <要素に追加されPHONENO >。
document.write(x.getElementsByTagName( "PhoneNo")[0] .childNodes [0] .nodeValue); 新しいテキストノード値を要素<PhoneNo>に書き込みます。
実行
このファイルをサーバーパスにcreatetextnode_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、属性値を次のように取得します。つまり、PhoneNO:Im new textnodeです。
新しいコメントノードを作成する
createComment()メソッドは、新しいコメントノードを作成します。コメントノードは、コード機能を簡単に理解できるようにプログラムに含まれています。
構文
createComment()を使用する構文は次のとおりです-
var_name = xmldoc.createComment("tagname");
どこ、
var_name-は、新しいコメントノードの名前を保持するユーザー定義の変数名です。
( "tagname") -作成される新しいコメントノードの名前です。
例
次の例(createcommentnode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、XMLドキュメントに新しいコメントノード「Companyistheparentnode 」を作成します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
}
else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_comment = xmlDoc.createComment("Company is the parent node");
x = xmlDoc.getElementsByTagName("Company")[0];
x.appendChild(create_comment);
document.write(x.lastChild.nodeValue);
</script>
</body>
</html>
上記の例では-
create_comment = xmlDoc.createComment( "会社は親ノードです") creates a specified comment line。
x.appendChild(create_comment)この行の「x」は、コメント行が追加される要素<Company>の名前を保持します。
実行
このファイルをサーバーパスにcreatecommentnode_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパス上にある必要があります)。Companyは親ノードであるため、出力では属性値を取得します。
新しいCDATAセクションノードを作成する
createCDATASection()メソッドは、新しいCDATAセクションノードを作成します。新しく作成されたCDATAセクションノードが要素オブジェクトに存在する場合、それは新しいノードに置き換えられます。
構文
createCDATASection()を使用する構文は次のとおりです-
var_name = xmldoc.createCDATASection("tagname");
どこ、
var_name-は、新しいCDATAセクションノードの名前を保持するユーザー定義の変数名です。
( "tagname") -作成される新しいCDATAセクションノードの名前です。
例
次の例(createcdatanode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、XMLドキュメントに新しいCDATAセクションノード「CreateCDATAExample 」を作成します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
}
else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_CDATA = xmlDoc.createCDATASection("Create CDATA Example");
x = xmlDoc.getElementsByTagName("Employee")[0];
x.appendChild(create_CDATA);
document.write(x.lastChild.nodeValue);
</script>
</body>
</html>
上記の例では-
create_CDATA = xmlDoc.createCDATASection( "Create CDATA Example")は、新しいCDATAセクションノード"Create CDATAExample"を作成します。
x.appendChild(create_CDATA)ここで、xは、CDATAノード値が追加される0でインデックス付けされた指定された要素<Employee>を保持します。
実行
このファイルをサーバーパスにcreatecdatanode_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、Create CDATAExampleとして属性値を取得します。
新しい属性ノードを作成します
新しい属性ノードを作成するには、メソッドsetAttributeNode()を使用します。新しく作成された属性ノードが要素オブジェクトに存在する場合、それは新しいものに置き換えられます。
構文
createElement()メソッドを使用するための構文は次のとおりです。
var_name = xmldoc.createAttribute("tagname");
どこ、
var_name-は、新しい属性ノードの名前を保持するユーザー定義の変数名です。
( "tagname") -作成される新しい属性ノードの名前です。
例
次の例(createattributenode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、XMLドキュメントに新しい属性ノードセクションを作成します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_a = xmlDoc.createAttribute("section");
create_a.nodeValue = "A";
x = xmlDoc.getElementsByTagName("Employee");
x[0].setAttributeNode(create_a);
document.write("New Attribute: ");
document.write(x[0].getAttribute("section"));
</script>
</body>
</html>
上記の例では-
create_a = xmlDoc.createAttribute( "Category")は、<section>という名前の属性を作成します。
create_a.nodeValue = "Management"は、属性<section>の値"A"を作成します。
x [0] .setAttributeNode(create_a)この属性値は、0でインデックス付けされたノード要素<Employee>に設定されます。
この章では、既存の要素へのノードについて説明します。それは次の手段を提供します-
既存の子ノードの前または後に新しい子ノードを追加します
テキストノード内にデータを挿入します
属性ノードを追加
次の方法を使用して、DOMの要素にノードを追加/追加できます-
- appendChild()
- insertBefore()
- insertData()
appendChild()
メソッドappendChild()は、既存の子ノードの後に新しい子ノードを追加します。
構文
appendChild()メソッドの構文は次のとおりです-
Node appendChild(Node newChild) throws DOMException
どこ、
newChild-追加するノードです
このメソッドは、追加されたノードを返します。
例
次の例(appendchildnode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、新しい子PhoneNoを要素<FirstName>に追加します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_e = xmlDoc.createElement("PhoneNo");
x = xmlDoc.getElementsByTagName("FirstName")[0];
x.appendChild(create_e);
document.write(x.getElementsByTagName("PhoneNo")[0].nodeName);
</script>
</body>
</html>
上記の例では-
createElement()メソッドを使用して、新しい要素PhoneNoが作成されます。
新しい要素PhoneNoは、メソッドappendChild()を使用して要素FirstNameに追加されます。
実行
このファイルをappendchildnode_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力では、属性値をPhoneNoとして取得します。
insertBefore()
メソッドinsertBefore()は、指定された子ノードの前に新しい子ノードを挿入します。
構文
insertBefore()メソッドの構文は次のとおりです-
Node insertBefore(Node newChild, Node refChild) throws DOMException
どこ、
newChild-挿入するノードです
refChild-参照ノード、つまり、新しいノードを挿入する必要があるノードです。
このメソッドは、挿入されているノードを返します。
例
次の例(insertnodebefore_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、指定された要素<Email>の前に新しい子Eメールを挿入します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_e = xmlDoc.createElement("Email");
x = xmlDoc.documentElement;
y = xmlDoc.getElementsByTagName("Email");
document.write("No of Email elements before inserting was: " + y.length);
document.write("<br>");
x.insertBefore(create_e,y[3]);
y=xmlDoc.getElementsByTagName("Email");
document.write("No of Email elements after inserting is: " + y.length);
</script>
</body>
</html>
上記の例では-
createElement()メソッドを使用して、新しい要素Emailが作成されます。
新しい要素Emailは、メソッドinsertBefore()を使用して、要素Emailの前に追加されます。
y.lengthは、新しい要素の前後に追加された要素の総数を示します。
実行
このファイルをサーバーパスにinsertnodebefore_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。次の出力を受け取ります-
No of Email elements before inserting was: 3
No of Email elements after inserting is: 4
insertData()
メソッドinsertData()は、指定された16ビット単位オフセットに文字列を挿入します。
構文
insertData()の構文は次のとおりです-
void insertData(int offset, java.lang.String arg) throws DOMException
どこ、
offset −は、挿入する文字オフセットです。
arg −はデータを挿入するためのキーワードです。2つのパラメーターoffsetとstringを、コンマで区切られた括弧で囲みます。
例
次の例(addtext_example.htm)は、XMLドキュメント( " node.xml ")をXML DOMオブジェクトに解析し、指定された位置の新しいデータMiddleNameを要素<FirstName>に挿入します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0];
document.write(x.nodeValue);
x.insertData(6,"MiddleName");
document.write("<br>");
document.write(x.nodeValue);
</script>
</body>
</html>
x.insertData(6,"MiddleName");−ここで、xは、指定された子名の名前、つまり<FirstName>を保持します。次に、このテキストノードに位置6から始まるデータ「MiddleName」を挿入します。
実行
このファイルをサーバーパスにaddtext_example.htmとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。出力で以下を受け取ります-
Tanmay
TanmayMiddleName
この章では、XMLDOMオブジェクトでのノードの置換操作について学習します。私たちが知っているように、DOM内のすべてはノードと呼ばれる階層情報ユニットで維持され、置換ノードはこれらの指定されたノードまたはテキストノードを更新する別の方法を提供します。
以下は、ノードを置き換える2つの方法です。
- replaceChild()
- replaceData()
replaceChild()
メソッドreplaceChild()は、指定されたノードを新しいノードに置き換えます。
構文
insertData()の構文は次のとおりです-
Node replaceChild(Node newChild, Node oldChild) throws DOMException
どこ、
newChild-は、子リストに追加する新しいノードです。
oldChild-は、リストで置き換えられるノードです。
このメソッドは、置き換えられたノードを返します。
例
次の例(replacenode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、指定されたノード<FirstName>を新しいノード<Name>に置き換えます。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.documentElement;
z = xmlDoc.getElementsByTagName("FirstName");
document.write("<b>Content of FirstName element before replace operation</b><br>");
for (i=0;i<z.length;i++) {
document.write(z[i].childNodes[0].nodeValue);
document.write("<br>");
}
//create a Employee element, FirstName element and a text node
newNode = xmlDoc.createElement("Employee");
newTitle = xmlDoc.createElement("Name");
newText = xmlDoc.createTextNode("MS Dhoni");
//add the text node to the title node,
newTitle.appendChild(newText);
//add the title node to the book node
newNode.appendChild(newTitle);
y = xmlDoc.getElementsByTagName("Employee")[0]
//replace the first book node with the new node
x.replaceChild(newNode,y);
z = xmlDoc.getElementsByTagName("FirstName");
document.write("<b>Content of FirstName element after replace operation</b><br>");
for (i = 0;i<z.length;i++) {
document.write(z[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
実行
このファイルをreplacenode_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。以下のような出力が得られます−
Content of FirstName element before replace operation
Tanmay
Taniya
Tanisha
Content of FirstName element after replace operation
Taniya
Tanisha
replaceData()
メソッドreplaceData()は、指定された16ビット単位オフセットで始まる文字を指定された文字列に置き換えます。
構文
replaceData()の構文は次のとおりです-
void replaceData(int offset, int count, java.lang.String arg) throws DOMException
どこ
offset −は、置換を開始するオフセットです。
count −は、置き換える16ビットユニットの数です。オフセットとカウントの合計が長さを超えると、データの最後までのすべての16ビット単位が置き換えられます。
引数- DOMStringの範囲を交換しなければならないと。
例
次の例(replacedata_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、それを置き換えます。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("ContactNo")[0].childNodes[0];
document.write("<b>ContactNo before replace operation:</b> "+x.nodeValue);
x.replaceData(1,5,"9999999");
document.write("<br>");
document.write("<b>ContactNo after replace operation:</b> "+x.nodeValue);
</script>
</body>
</html>
上記の例では-
x.replaceData(2,3、 "999"); −ここで、xは、指定された要素<ContactNo>のテキストを保持します。このテキストは、位置1から長さ5までの新しいテキスト「9999999」に置き換えられます。
実行
このファイルをreplacedata_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。以下のような出力が得られます−
ContactNo before replace operation: 1234567890
ContactNo after replace operation: 199999997890
この章では、XMLDOMのノードの削除操作について学習します。ノードの削除操作は、指定されたノードをドキュメントから削除します。この操作は、テキストノード、要素ノード、属性ノードなどのノードを削除するために実装できます。
以下は、ノードの削除操作に使用される方法です。
removeChild()
removeAttribute()
removeChild()
メソッドremoveChild()は、oldChildで示される子ノードを子のリストから削除し、それを返します。子ノードを削除することは、テキストノードを削除することと同じです。したがって、子ノードを削除すると、それに関連付けられているテキストノードが削除されます。
構文
removeChild()を使用する構文は次のとおりです-
Node removeChild(Node oldChild) throws DOMException
どこ、
oldChild-は削除されるノードです。
このメソッドは、削除されたノードを返します。
例-現在のノードを削除する
次の例(removecurrentnode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、指定されたノード<ContactNo>を親ノードから削除します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
document.write("<b>Before remove operation, total ContactNo elements: </b>");
document.write(xmlDoc.getElementsByTagName("ContactNo").length);
document.write("<br>");
x = xmlDoc.getElementsByTagName("ContactNo")[0];
x.parentNode.removeChild(x);
document.write("<b>After remove operation, total ContactNo elements: </b>");
document.write(xmlDoc.getElementsByTagName("ContactNo").length);
</script>
</body>
</html>
上記の例では-
x = xmlDoc.getElementsByTagName( "ContactNo")[0]は、0でインデックス付けされた要素<ContactNo>を取得します。
x.parentNode.removeChild(x); 0でインデックス付けされた要素<ContactNo>を親ノードから削除します。
実行
このファイルをremovecurrentnode_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。次の結果が得られます-
Before remove operation, total ContactNo elements: 3
After remove operation, total ContactNo elements: 2
例-テキストノードを削除する
次の例(removetextNode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、指定された子ノード<FirstName>を削除します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("FirstName")[0];
document.write("<b>Text node of child node before removal is:</b> ");
document.write(x.childNodes.length);
document.write("<br>");
y = x.childNodes[0];
x.removeChild(y);
document.write("<b>Text node of child node after removal is:</b> ");
document.write(x.childNodes.length);
</script>
</body>
</html>
上記の例では-
x = xmlDoc.getElementsByTagName( "FirstName")[0]; −最初の要素<FirstName>を0でインデックス付けされたxに取得します。
y = x.childNodes [0]; −この行のyは、削除する子ノードを保持します。
x.removeChild(y); −指定された子ノードを削除します。
実行
このファイルをremovetextNode_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。次の結果が得られます-
Text node of child node before removal is: 1
Text node of child node after removal is: 0
removeAttribute()
メソッドremoveAttribute()は、要素の属性を名前で削除します。
構文
removeAttribute()を使用する構文は次のとおりです-
void removeAttribute(java.lang.String name) throws DOMException
どこ、
名前は-削除する属性の名前です。
例
次の例(removeelementattribute_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、指定された属性ノードを削除します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName('Employee');
document.write(x[1].getAttribute('category'));
document.write("<br>");
x[1].removeAttribute('category');
document.write(x[1].getAttribute('category'));
</script>
</body>
</html>
上記の例では-
document.write(x [1] .getAttribute( 'category')); −1番目の位置でインデックス付けされた属性カテゴリの値が呼び出されます。
x [1] .removeAttribute( 'category'); −属性値を削除します。
実行
このファイルをremoveelementattribute_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。次の結果が得られます-
Non-Technical
null
この章では、XMLDOMオブジェクトでのノードの複製操作について説明します。ノードの複製操作は、指定されたノードの複製コピーを作成するために使用されます。この操作にはcloneNode()が使用されます。
cloneNode()
このメソッドは、このノードの複製を返します。つまり、ノードの汎用コピーコンストラクターとして機能します。重複ノードには親がなく(parentNodeはnull)、ユーザーデータもありません。
構文
cloneNodeを()メソッドは、次の構文を持っています-
Node cloneNode(boolean deep)
deep − trueの場合、指定されたノードの下にサブツリーを再帰的に複製します。falseの場合、ノード自体(および要素の場合はその属性)のみを複製します。
このメソッドは重複ノードを返します。
例
次の例(clonenode_example.htm)は、XMLドキュメント(node.xml)をXML DOMオブジェクトに解析し、最初のEmployee要素のディープコピーを作成します。
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName('Employee')[0];
clone_node = x.cloneNode(true);
xmlDoc.documentElement.appendChild(clone_node);
firstname = xmlDoc.getElementsByTagName("FirstName");
lastname = xmlDoc.getElementsByTagName("LastName");
contact = xmlDoc.getElementsByTagName("ContactNo");
email = xmlDoc.getElementsByTagName("Email");
for (i = 0;i < firstname.length;i++) {
document.write(firstname[i].childNodes[0].nodeValue+'
'+lastname[i].childNodes[0].nodeValue+',
'+contact[i].childNodes[0].nodeValue+', '+email[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
上記の例でわかるように、cloneNode()パラメータをtrueに設定しました。したがって、Employee要素の下の各子要素がコピーまたは複製されます。
実行
このファイルをclonenode_example.htmとしてサーバーパスに保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。以下のような出力が得られます−
Tanmay Patil, 1234567890, [email protected]
Taniya Mishra, 1234667898, [email protected]
Tanisha Sharma, 1234562350, [email protected]
Tanmay Patil, 1234567890, [email protected]
最初のEmployee要素が完全に複製されていることがわかります。
ノードインターフェイスは、ドキュメントオブジェクトモデル全体の主要なデータ型です。ノードは、ドキュメントツリー全体で単一のXML要素を表すために使用されます。
ノードは、属性ノード、テキストノード、またはその他のノードである任意のタイプにすることができます。属性nodeName、nodeValue、および属性は、特定の派生インターフェースにキャストダウンせずにノード情報を取得するメカニズムとして含まれています。
属性
次の表に、Nodeオブジェクトの属性を示します-
属性 | タイプ | 説明 |
---|---|---|
属性 | NamedNodeMap | これは、このノードの属性(要素の場合)を含むNamedNodeMapタイプであり、それ以外の場合はnullです。これは削除されました。仕様を参照 |
baseURI | DOMString | ノードの絶対ベースURIを指定するために使用されます。 |
childNodes | NodeList | これは、このノードのすべての子を含むNodeListです。子がない場合、これはノードを含まないNodeListです。 |
第一子 | ノード | ノードの最初の子を指定します。 |
最後の子 | ノード | ノードの最後の子を指定します。 |
localName | DOMString | これは、ノードのローカル部分の名前を指定するために使用されます。これは削除されました。仕様を参照してください。 |
namespaceURI | DOMString | ノードの名前空間URIを指定します。これは削除されました。仕様を参照 |
nextSibling | ノード | このノードの直後のノードを返します。そのようなノードがない場合、これはnullを返します。 |
nodeName | DOMString | タイプに応じた、このノードの名前。 |
nodeType | unsigned short | これは、基になるオブジェクトのタイプを表すコードです。 |
nodeValue | DOMString | タイプに応じてノードの値を指定するために使用されます。 |
ownerDocument | 資料 | ノードに関連付けられたDocumentオブジェクトを指定します。 |
parentNode | ノード | このプロパティは、ノードの親ノードを指定します。 |
プレフィックス | DOMString | このプロパティは、ノードの名前空間プレフィックスを返します。これは削除されました。仕様を参照 |
previousSibling | ノード | これは、現在のノードの直前のノードを指定します。 |
textContent | DOMString | これは、ノードのテキストコンテンツを指定します。 |
ノードタイプ
以下のようにノードタイプをリストしました-
- ELEMENT_NODE
- ATTRIBUTE_NODE
- ENTITY_NODE
- ENTITY_REFERENCE_NODE
- DOCUMENT_FRAGMENT_NODE
- TEXT_NODE
- CDATA_SECTION_NODE
- COMMENT_NODE
- PROCESSING_INSTRUCTION_NODE
- DOCUMENT_NODE
- DOCUMENT_TYPE_NODE
- NOTATION_NODE
メソッド
以下の表に、さまざまなノードオブジェクトメソッドを示します-
S.No. | 方法と説明 |
---|---|
1 | appendChild(ノードnewChild) このメソッドは、指定された要素ノードの最後の子ノードの後にノードを追加します。追加されたノードを返します。 |
2 | cloneNode(ブールディープ) このメソッドは、派生クラスでオーバーライドされたときに、重複ノードを作成するために使用されます。複製されたノードを返します。 |
3 | compareDocumentPosition(ノードその他) このメソッドは、ドキュメントの順序に従って、現在のノードの位置を指定されたノードと比較するために使用されます。unsigned shortを返します。これは、ノードが参照ノードに対してどのように配置されているかを示します。 |
4 | getFeature(DOMString feature, DOMString version) 指定された機能とバージョンの特殊なAPIを実装するDOMオブジェクトを返します(存在する場合)。オブジェクトがない場合はnullを返します。これは削除されました。仕様を参照してください。 |
5 | getUserData(DOMString key) このノードのキーに関連付けられているオブジェクトを取得します。同じキーでsetUserDataを呼び出して、オブジェクトを最初にこのノードに設定しておく必要があります。このノードの指定されたキーに関連付けられたDOMUserDataを返します。存在しない場合はnullを返します。これは削除されました。仕様を参照してください。 |
6 | hasAttributes() このノード(要素の場合)に属性があるかどうかを返します。指定されたノードに属性が存在する場合はtrueを返し、存在しない場合はfalseを返します。これは削除されました。仕様を参照してください。 |
7 | hasChildNodes() このノードに子があるかどうかを返します。このメソッドは、現在のノードに子ノードがある場合はtrueを返し、そうでない場合はfalseを返します。 |
8 | insertBefore(Node newChild、Node refChild) このメソッドは、このノードの既存の子の直前に、このノードの子として新しいノードを挿入するために使用されます。挿入されているノードを返します。 |
9 | isDefaultNamespace(DOMString namespaceURI) このメソッドは、引数として名前空間URIを受け入れ、返すブールの値と真の名前空間が指定されたノードまたは上のデフォルトの名前空間である場合にはfalseではない場合。 |
10 | isEqualNode(Node arg) このメソッドは、2つのノードが等しいかどうかをテストします。ノードが等しい場合はtrueを返し、そうでない場合はfalseを返します。 |
11 | isSameNode(Node other) このメソッドは、現在のノードが指定されたノードと同じノードであるかどうかを返します。ノードが同じ場合はtrueを返し、そうでない場合はfalseを返します。これは削除されました。仕様を参照してください。 |
12 | isSupported(DOMString feature, DOMString version) このメソッドは、指定されたDOMモジュールが現在のノードでサポートされているかどうかを返します。指定された機能がこのノードでサポートされている場合はtrueを返し、そうでない場合はfalseを返します。これは削除されました。仕様を参照してください。 |
13 | lookupNamespaceURI(DOMStringプレフィックス) このメソッドは、名前空間プレフィックスに関連付けられた名前空間のURIを取得します。 |
14 | lookupPrefix(DOMString namespaceURI) このメソッドは、名前空間URIの現在の名前空間で定義されている最も近いプレフィックスを返します。見つかった場合は関連する名前空間プレフィックスを返し、見つからなかった場合はnullを返します。 |
15 | ノーマライズ() 正規化は、要素、コメント、処理命令、CDATAセクション、およびエンティティ参照を含むノードの構造がテキストノードを分離する通常の形式を定義する属性ノードを含むすべてのテキストノードを追加します。つまり、隣接するテキストノードも空のテキストノードもありません。 |
16 | removeChild(ノードoldChild) このメソッドは、指定された子ノードを現在のノードから削除するために使用されます。これにより、削除されたノードが返されます。 |
17 | replaceChild(ノードnewChild、ノードoldChild) このメソッドは、古い子ノードを新しいノードに置き換えるために使用されます。これにより、置き換えられたノードが返されます。 |
18 | setUserData(DOMString key, DOMUserData data, UserDataHandler handler) このメソッドは、オブジェクトをこのノードのキーに関連付けます。同じキーでgetUserDataを呼び出すことにより、後でこのノードからオブジェクトを取得できます。これにより、このノードの指定されたキーに以前に関連付けられていたDOMUserDataが返されます。これは削除されました。仕様を参照してください。 |
NodeListオブジェクトは、順序付けられたノードのコレクションの抽象化を指定します。NodeListの項目には、0から始まる整数インデックスを介してアクセスできます。
属性
次の表に、NodeListオブジェクトの属性を示します-
属性 | タイプ | 説明 |
---|---|---|
長さ | unsigned long | ノードリスト内のノード数を示します。 |
メソッド
以下は、NodeListオブジェクトの唯一のメソッドです。
S.No. | 方法と説明 |
---|---|
1 | 項目() コレクション内のインデックス番目のアイテムを返します。indexがリスト内のノードの数以上の場合、これはnullを返します。 |
NamedNodeMapオブジェクトは、名前によってアクセスできるノードのコレクションを表すために使用されます。
属性
次の表に、NamedNodeMapオブジェクトのプロパティを示します。
属性 | タイプ | 説明 |
---|---|---|
長さ | unsigned long | このマップ内のノードの数を示します。有効な子ノードインデックスの範囲は、0から長さ1までです。 |
メソッド
次の表に、NamedNodeMapオブジェクトのメソッドを示します。
S.No. | 方法と説明 |
---|---|
1 | getNamedItem() 名前で指定されたノードを取得します。 |
2 | getNamedItemNS() ローカル名と名前空間URIで指定されたノードを取得します。 |
3 | アイテム() マップ内のインデックス番目のアイテムを返します。indexがこのマップのノード数以上の場合、これはnullを返します。 |
4 | removeNamedItem() 名前で指定されたノードを削除します。 |
5 | removeNamedItemNS() ローカル名と名前空間URIで指定されたノードを削除します。 |
6 | setNamedItem() nodeName属性を使用してノードを追加します。その名前のノードがこのマップにすでに存在する場合は、新しいノードに置き換えられます。 |
7 | setNamedItemNS() namespaceURIとlocalNameを使用してノードを追加します。その名前空間URIとそのローカル名を持つノードがこのマップにすでに存在する場合、そのノードは新しいノードに置き換えられます。ノードを単独で置き換えても効果はありません。 |
するDOMImplementationオブジェクトは、ドキュメントオブジェクトモデルの特定のインスタンスに依存しない操作を実行するための多数の方法を提供します。
メソッド
次の表に、DOMImplementationオブジェクトのメソッドを示します。
S.No. | 方法と説明 |
---|---|
1 | createDocument(namespaceURI、qualifiedName、doctype) これは、そのドキュメント要素を使用して、指定されたタイプのDOMドキュメントオブジェクトを作成します。 |
2 | createDocumentType(qualifiedName、publicId、systemId) 空のDocumentTypeノードを作成します。 |
3 | getFeature(feature, version) このメソッドは、指定された機能とバージョンの特殊なAPIを実装する特殊なオブジェクトを返します。これは削除されました。仕様を参照してください。 |
4 | hasFeature(機能、バージョン) このメソッドは、DOM実装が特定の機能とバージョンを実装しているかどうかをテストします。 |
DocumentTypeオブジェクトは、ドキュメントのデータにアクセスするための鍵であり、文書で、doctype属性がnull値やDocumentTypeのオブジェクト値のいずれかを持つことができます。これらのDocumentTypeオブジェクトは、XMLドキュメント用に記述されたエンティティへのインターフェイスとして機能します。
属性
次の表に、DocumentTypeオブジェクトの属性を示します-
属性 | タイプ | 説明 |
---|---|---|
名前 | DOMString | キーワード!DOCTYPEのすぐ隣に書かれているDTDの名前を返します。 |
エンティティ | NamedNodeMap | DTDで宣言された外部エンティティと内部エンティティの両方を含むNamedNodeMapオブジェクトを返します。 |
表記 | NamedNodeMap | DTDで宣言された表記を含むNamedNodeMapを返します。 |
internalSubset | DOMString | 内部サブセットを文字列として返すか、存在しない場合はnullを返します。これは削除されました。仕様を参照してください。 |
publicId | DOMString | 外部サブセットのパブリック識別子を返します。 |
systemId | DOMString | 外部サブセットのシステム識別子を返します。これは絶対URIである場合とそうでない場合があります。 |
メソッド
DocumentTypeは、その親であるNodeからメソッドを継承し、ChildNodeインターフェイスを実装します。
ProcessingInstructionは、XMLドキュメントのプロローグセクションに通常含まれているアプリケーション固有の情報を提供します。
処理命令(PI)を使用して、アプリケーションに情報を渡すことができます。PIは、マークアップの外側のドキュメントのどこにでも表示できます。それらは、文書型定義(DTD)を含むプロローグ、テキストコンテンツ、または文書の後に表示できます。
PIは特別なタグで始まります <? そしてで終わる ?>。内容の処理は文字列の直後に終了します?> に遭遇しました。
属性
次の表に、ProcessingInstructionオブジェクトの属性を示します。
属性 | タイプ | 説明 |
---|---|---|
データ | DOMString | これは、?>の直前でアプリケーションが処理する情報を説明する文字です。 |
目標 | DOMString | これは、命令またはデータが向けられているアプリケーションを識別します。 |
エンティティインターフェイスは、XMLドキュメント内の解析済みまたは未解析の既知のエンティティを表します。たnodeNameから継承された属性ノードは、エンティティの名前が含まれています。
エンティティオブジェクトには親ノードがなく、後続のノードはすべて読み取り専用です。
属性
次の表に、エンティティオブジェクトの属性を示します-
属性 | タイプ | 説明 |
---|---|---|
inputEncoding | DOMString | これは、外部の解析済みエンティティによって使用されるエンコーディングを指定します。内部サブセットのエンティティである場合、または不明な場合、その値はnullです。 |
notationName | DOMString | 解析されていないエンティティの場合、表記の名前が示され、解析されたエンティティの値はnullになります。 |
publicId | DOMString | エンティティに関連付けられているパブリック識別子の名前を示します。 |
systemId | DOMString | エンティティに関連付けられているシステム識別子の名前を示します。 |
xmlEncoding | DOMString | これは、外部の解析済みエンティティのテキスト宣言の一部として含まれているxmlエンコーディングを提供し、それ以外の場合はnullを提供します。 |
xmlVersion | DOMString | これは、外部の解析済みエンティティのテキスト宣言の一部として含まれているxmlバージョンを提供し、それ以外の場合はnullを提供します。 |
実体参照オブジェクトは、テキストを置き換えるためにスコープを提供するXMLドキュメントに挿入されている一般的な実体参照です。EntityReferenceオブジェクトは、HTMLまたはXMLプロセッサによって展開されていると見なされるため、事前定義されたエンティティに対しては機能しません。
このインターフェースには独自のプロパティやメソッドはありませんが、ノードから継承します。
この章では、XML DOMNotationオブジェクトについて学習します。表記オブジェクトプロパティは、表記属性、特定の処理命令、または非XMLデータを持つ要素の形式を認識するためのスコープを提供します。Node Objectのプロパティとメソッドは、Notation Objectもノードと見なされるため、NotationObjectで実行できます。
このオブジェクトは、ノードからメソッドとプロパティを継承します。そのnodeNameは表記名です。親がいません。
属性
次の表に、Notationオブジェクトの属性を示します-
属性 | タイプ | 説明 |
---|---|---|
publicID | DOMString | 表記に関連付けられた公開識別子の名前を示します。 |
systemID | DOMString | 表記に関連付けられたシステム識別子の名前を示します。 |
XML要素は、XMLの構成要素として定義できます。要素は、テキスト、要素、属性、メディアオブジェクト、またはこれらすべてを保持するコンテナとして動作できます。パーサーが整形式に対してXMLドキュメントを解析するときはいつでも、パーサーは要素ノードをナビゲートします。要素ノードには、テキストノードと呼ばれるテキストが含まれています。
要素オブジェクトはノードオブジェクトと見なされるため、要素オブジェクトはノードオブジェクトのプロパティとメソッドを継承します。ノードオブジェクトのプロパティとメソッドの他に、次のプロパティとメソッドがあります。
プロパティ
次の表に、Elementオブジェクトの属性を示します-
属性 | タイプ | 説明 |
---|---|---|
タグ名 | DOMString | 指定された要素のタグの名前を示します。 |
schemaTypeInfo | TypeInfo | この要素に関連付けられているタイプ情報を表します。これは削除されました。仕様を参照してください。 |
メソッド
以下の表に、要素オブジェクトのメソッドを示します-
メソッド | タイプ | 説明 |
---|---|---|
getAttribute() | DOMString | 指定された要素に存在する場合、属性の値を取得します。 |
getAttributeNS() | DOMString | ローカル名と名前空間URIによって属性値を取得します。 |
getAttributeNode() | Attr | 現在の要素から属性ノードの名前を取得します。 |
getAttributeNodeNS() | Attr | ローカル名と名前空間URIによってAttrノードを取得します。 |
getElementsByTagName() | NodeList | 指定されたタグ名を持つすべての子孫要素のNodeListをドキュメント順に返します。 |
getElementsByTagNameNS() | NodeList | 指定されたローカル名と名前空間URIを持つすべての子孫要素のNodeListをドキュメント順に返します。 |
hasAttribute() | ブール値 | 指定された名前の属性がこの要素に指定されているか、デフォルト値がある場合はtrueを返し、それ以外の場合はfalseを返します。 |
hasAttributeNS() | ブール値 | 指定されたローカル名と名前空間URIを持つ属性がこの要素に指定されているか、デフォルト値がある場合はtrueを返し、それ以外の場合はfalseを返します。 |
removeAttribute() | 戻り値なし | 名前で属性を削除します。 |
removeAttributeNS | 戻り値なし | ローカル名と名前空間URIによって属性を削除します。 |
removeAttributeNode() | Attr | 指定された属性ノードが要素から削除されます。 |
setAttribute() | 戻り値なし | 既存の要素に新しい属性値を設定します。 |
setAttributeNS() | 戻り値なし | 新しい属性を追加します。同じローカル名と名前空間URIを持つ属性が要素にすでに存在する場合、そのプレフィックスはqualifiedNameのプレフィックス部分に変更され、その値はvalueパラメーターに変更されます。 |
setAttributeNode() | Attr | 新しい属性ノードを既存の要素に設定します。 |
setAttributeNodeNS | Attr | 新しい属性を追加します。そのローカル名とその名前空間URIを持つ属性が要素にすでに存在する場合、その属性は新しい属性に置き換えられます。 |
setIdAttribute | 戻り値なし | パラメータisIdがtrueの場合、このメソッドは、指定された属性がユーザー決定のID属性であることを宣言します。これは削除されました。仕様を参照してください。 |
setIdAttributeNS | 戻り値なし | パラメータisIdがtrueの場合、このメソッドは、指定された属性がユーザー決定のID属性であることを宣言します。これは削除されました。仕様を参照してください。 |
Attrインターフェースは、Elementオブジェクトの属性を表します。通常、属性の許容値は、ドキュメントに関連付けられたスキーマで定義されます。Attrオブジェクトは、実際にはそれらが記述する要素の子ノードではないため、ドキュメントツリーの一部とは見なされません。したがって、子ノードparentNode、previousSibling、およびnextSiblingの場合、属性値はnullです。
属性
次の表に、Attributeオブジェクトの属性を示します-
属性 | タイプ | 説明 |
---|---|---|
名前 | DOMString | これにより、属性の名前がわかります。 |
指定 | ブール値 | これはブール値であり、属性値がドキュメントに存在する場合にtrueを返します。 |
値 | DOMString | 属性の値を返します。 |
ownerElement | 素子 | 属性が関連付けられているノード、または属性が使用されていない場合はnullを指定します。 |
isId | ブール値 | 属性がタイプIDであることがわかっている(つまり、その所有者要素の識別子を含む)かどうかを返します。 |
この章では、XML DOMCDATASectionオブジェクトについて学習します。XMLドキュメント内に存在するテキストは、宣言されている内容に応じて解析されるか、解析されません。テキストがParseCharacter Data(PCDATA)として宣言されている場合、パーサーによって解析され、XMLドキュメントがXMLDOMオブジェクトに変換されます。一方、テキストが未解析の文字データ(CDATA)として宣言されている場合、その中のテキストはXMLパーサーによって解析されません。これらはマークアップとは見なされず、エンティティを拡張しません。
CDATASectionオブジェクトを使用する目的は、マークアップと見なされる文字を含むテキストのブロックをエスケープすることです。 "]]>"、これは、CDATAセクションを終了するCDATAセクションで認識される唯一の区切り文字です。
CharacterData.data属性は、CDATAセクションに含まれるテキストを保持します。このインターフェイスは、テキストインターフェイスを介してCharatcterDataインターフェイスを継承します。
CDATASectionオブジェクトに定義されたメソッドと属性はありません。テキストインターフェイスを直接実装するだけ です。
この章では、Commentオブジェクトについて学習します。コメントは、XMLコードの目的を理解するためのメモまたは行として追加されます。コメントを使用して、関連するリンク、情報、および用語を含めることができます。これらは、XMLコードのどこにでも表示される可能性があります。
コメントインターフェイスは、コメントの内容を表すCharacterDataインターフェイスを継承します。
構文
XMLコメントの構文は次のとおりです-
<!-------Your comment----->
コメントは<!-で始まり、->で終わります。文字間のコメントとしてテキストメモを追加できます。1つのコメントを他のコメントの中にネストしてはなりません。
Commentオブジェクトに定義されたメソッドと属性はありません。親のCharacterDataの値を継承し、間接的に Nodeの値を継承し ます。
XMLHttpRequestオブジェクトは、JavaScript、JScript、VBScript、その他のWebブラウザーなどの多くのスクリプト言語でXMLデータを転送および操作するために使用できる、Webページのクライアント側とサーバー側の間に媒体を確立します。
XMLHttpRequestオブジェクトを使用すると、ページ全体をリロードせずにWebページの一部を更新し、ページがロードされた後にサーバーからデータを要求および受信し、データをサーバーに送信することができます。
構文
XMLHttpRequestオブジェクトは次のようにインスタンス化できます-
xmlhttp = new XMLHttpRequest();
IE5とIE6を含むすべてのブラウザーを処理するには、ブラウザーが以下のようにXMLHttpRequestオブジェクトをサポートしているかどうかを確認します。
if(window.XMLHttpRequest) // for Firefox, IE7+, Opera, Safari, ... {
xmlHttp = new XMLHttpRequest();
} else if(window.ActiveXObject) // for Internet Explorer 5 or 6 {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
XMLHttpRequestオブジェクトを使用してXMLファイルをロードする例はここで参照できます
メソッド
次の表に、XMLHttpRequestオブジェクトのメソッドを示します-
S.No. | 方法と説明 |
---|---|
1 | abort() 現在行われている要求を終了します。 |
2 | getAllResponseHeaders() すべての応答ヘッダーを文字列として返します。応答が受信されていない場合はnullを返します。 |
3 | getResponseHeader() 指定されたヘッダーのテキストを含む文字列を返します。応答がまだ受信されていないか、ヘッダーが応答に存在しない場合はnullを返します。 |
4 | open(method,url,async,uname,pswd) これは、Sendメソッドと組み合わせて使用され、サーバーに要求を送信します。openメソッドは、次のパラメーターを指定します-
|
5 | send(string) これは、Openメソッドと組み合わせて機能するリクエストを送信するために使用されます。 |
6 | setRequestHeader() ヘッダーには、リクエストの送信先のラベルと値のペアが含まれています。 |
属性
次の表に、XMLHttpRequestオブジェクトの属性を示します-
S.No. | 属性と説明 |
---|---|
1 | onreadystatechange これは、状態が変化するたびに設定されるイベントベースのプロパティです。 |
2 | readyState これは、XMLHttpRequestオブジェクトの現在の状態を記述します。readyStateプロパティには5つの可能な状態があります-
|
3 | responseText このプロパティは、サーバーからの応答がテキストファイルの場合に使用されます。 |
4 | responseXML このプロパティは、サーバーからの応答がXMLファイルである場合に使用されます。 |
5 | status Httpリクエストオブジェクトのステータスを数値で示します。たとえば、「404」または「200」です。 |
6 | statusText Httpリクエストオブジェクトのステータスを文字列として提供します。たとえば、「見つかりません」または「OK」です。 |
例
node.xmlの内容は以下のとおりです-
<?xml version = "1.0"?>
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
リソースファイルの特定の情報を取得する
次の例は、メソッドgetResponseHeader()とプロパティreadStateを使用してリソースファイルの特定の情報を取得する方法を示しています。
<!DOCTYPE html>
<html>
<head>
<meta http-equiv = "content-type" content = "text/html; charset = iso-8859-2" />
<script>
function loadXMLDoc() {
var xmlHttp = null;
if(window.XMLHttpRequest) // for Firefox, IE7+, Opera, Safari, ... {
xmlHttp = new XMLHttpRequest();
}
else if(window.ActiveXObject) // for Internet Explorer 5 or 6 {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlHttp;
}
function makerequest(serverPage, myDiv) {
var request = loadXMLDoc();
request.open("GET", serverPage);
request.send(null);
request.onreadystatechange = function() {
if (request.readyState == 4) {
document.getElementById(myDiv).innerHTML = request.getResponseHeader("Content-length");
}
}
}
</script>
</head>
<body>
<button type = "button" onclick="makerequest('/dom/node.xml', 'ID')">Click me to get the specific ResponseHeader</button>
<div id = "ID">Specific header information is returned.</div>
</body>
</html>
実行
このファイルをelementattribute_removeAttributeNS.htmとしてサーバーパスに保存します(このファイルとnode_ns.xmlはサーバー内の同じパスにある必要があります)。以下のような出力が得られます−
Before removing the attributeNS: en
After removing the attributeNS: null
リソースファイルのヘッダー情報を取得する
次の例は、メソッドを使用してリソースファイルのヘッダー情報を取得する方法を示しています getAllResponseHeaders() プロパティを使用する readyState。
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-2" />
<script>
function loadXMLDoc() {
var xmlHttp = null;
if(window.XMLHttpRequest) // for Firefox, IE7+, Opera, Safari, ... {
xmlHttp = new XMLHttpRequest();
} else if(window.ActiveXObject) // for Internet Explorer 5 or 6 {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlHttp;
}
function makerequest(serverPage, myDiv) {
var request = loadXMLDoc();
request.open("GET", serverPage);
request.send(null);
request.onreadystatechange = function() {
if (request.readyState == 4) {
document.getElementById(myDiv).innerHTML = request.getAllResponseHeaders();
}
}
}
</script>
</head>
<body>
<button type = "button" onclick = "makerequest('/dom/node.xml', 'ID')">
Click me to load the AllResponseHeaders</button>
<div id = "ID"></div>
</body>
</html>
実行
このファイルをサーバーパスにhttp_allheader.htmlとして保存します(このファイルとnode.xmlはサーバー内の同じパスにある必要があります)。以下のような出力が得られます(ブラウザによって異なります)-
Date: Sat, 27 Sep 2014 07:48:07 GMT Server: Apache Last-Modified:
Wed, 03 Sep 2014 06:35:30 GMT Etag: "464bf9-2af-50223713b8a60" Accept-Ranges: bytes Vary: Accept-Encoding,User-Agent
Content-Encoding: gzip Content-Length: 256 Content-Type: text/xml
DOMExceptionは、メソッドまたはプロパティを使用した場合に起き異常事象を表します。
プロパティ
以下の表に、DOMExceptionオブジェクトのプロパティを示します。
S.No. | プロパティと説明 |
---|---|
1 | name エラー定数に関連付けられた文字列の1つを含むDOMStringを返します(次の表を参照)。 |
エラーの種類
S.No. | タイプと説明 |
---|---|
1 | IndexSizeError インデックスが許容範囲内にありません。たとえば、これはRangeオブジェクトによってスローされる可能性があります。(レガシーコード値:1およびレガシー定数名:INDEX_SIZE_ERR) |
2 | HierarchyRequestError ノードツリーの階層が正しくありません。(レガシーコード値:3およびレガシー定数名:HIERARCHY_REQUEST_ERR) |
3 | WrongDocumentError オブジェクトが間違ったドキュメントにあります。(レガシーコード値:4およびレガシー定数名:WRONG_DOCUMENT_ERR) |
4 | InvalidCharacterError 文字列に無効な文字が含まれています。(レガシーコード値:5およびレガシー定数名:INVALID_CHARACTER_ERR) |
5 | NoModificationAllowedError オブジェクトは変更できません。(レガシーコード値:7およびレガシー定数名:NO_MODIFICATION_ALLOWED_ERR) |
6 | NotFoundError オブジェクトがここに見つかりません。(レガシーコード値:8およびレガシー定数名:NOT_FOUND_ERR) |
7 | NotSupportedError 操作はサポートされていません。(レガシーコード値:9およびレガシー定数名:NOT_SUPPORTED_ERR) |
8 | InvalidStateError オブジェクトは無効な状態です。(レガシーコード値:11およびレガシー定数名:INVALID_STATE_ERR) |
9 | SyntaxError 文字列が予期されたパターンと一致しませんでした。(レガシーコード値:12およびレガシー定数名:SYNTAX_ERR) |
10 | InvalidModificationError この方法でオブジェクトを変更することはできません。(レガシーコード値:13およびレガシー定数名:INVALID_MODIFICATION_ERR) |
11 | NamespaceError この操作は、XMLの名前空間では許可されていません。(レガシーコード値:14およびレガシー定数名:NAMESPACE_ERR) |
12 | InvalidAccessError オブジェクトは、操作または引数をサポートしていません。(レガシーコード値:15およびレガシー定数名:INVALID_ACCESS_ERR) |
13 | TypeMismatchError オブジェクトのタイプが予期されたタイプと一致しません。(レガシーコード値:17およびレガシー定数名:TYPE_MISMATCH_ERR)この値は非推奨になり、この値のDOMExceptionの代わりにJavaScriptTypeError例外が発生するようになりました。 |
14 | SecurityError 操作は安全ではありません。(レガシーコード値:18およびレガシー定数名:SECURITY_ERR) |
15 | NetworkError ネットワークエラーが発生しました。(レガシーコード値:19およびレガシー定数名:NETWORK_ERR) |
16 | AbortError 操作は中止されました。(レガシーコード値:20およびレガシー定数名:ABORT_ERR) |
17 | URLMismatchError 指定されたURLが別のURLと一致しません。(レガシーコード値:21およびレガシー定数名:URL_MISMATCH_ERR) |
18 | QuotaExceededError 割り当てを超えました。(レガシーコード値:22およびレガシー定数名:QUOTA_EXCEEDED_ERR) |
19 | TimeoutError 操作がタイムアウトしました。(レガシーコード値:23およびレガシー定数名:TIMEOUT_ERR) |
20 | InvalidNodeTypeError ノードが正しくないか、この操作の祖先が正しくありません。(レガシーコード値:24およびレガシー定数名:INVALID_NODE_TYPE_ERR) |
21 | DataCloneError オブジェクトのクローンを作成できません。(レガシーコード値:25およびレガシー定数名:DATA_CLONE_ERR) |
22 | EncodingError エンコードまたはデコード操作であるエンコード操作が失敗しました(レガシーコード値と定数名がありません)。 |
23 | NotReadableError 入出力の読み取り操作が失敗しました(レガシーコード値と定数名がありません)。 |
例
次の例は、整形式でないXMLドキュメントを使用するとDOMExceptionが発生する方法を示しています。
error.xmlの内容は以下のとおりです-
<?xml version = "1.0" encoding = "UTF-8" standalone = "no" ?>
<Company id = "companyid">
<Employee category = "Technical" id = "firstelement" type = "text/html">
<FirstName>Tanmay</first>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
次の例は、name属性の使用法を示しています-
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
try {
xmlDoc = loadXMLDoc("/dom/error.xml");
var node = xmlDoc.getElementsByTagName("to").item(0);
var refnode = node.nextSibling;
var newnode = xmlDoc.createTextNode('That is why you fail.');
node.insertBefore(newnode, refnode);
} catch(err) {
document.write(err.name);
}
</script>
</body>
</html>
実行
このファイルをdomexcption_name.htmlとしてサーバーパスに保存します(このファイルとerror.xmlはサーバー内の同じパスにある必要があります)。以下のような出力が得られます−
TypeError