XMLDOM-ノードの作成
この章では、ドキュメントオブジェクトのいくつかのメソッドを使用して新しいノードを作成する方法について説明します。これらのメソッドは、新しい要素ノード、テキストノード、コメントノード、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>に設定されます。