XMLSerializer
XMLSerializer
インターフェイスは serializeToString()
メソッドを提供します。これにより、 DOM ツリーを表す XML 文字列を構築することができます。
インスタンスメソッド
serializeToString()
-
文字列の形にシリアライズされたサブツリーを返します。
例
XML を文字列にシリアライズ
最初の基本的な例は、文書全体を XML を含む文字列にシリアライズします。
js
const s = new XMLSerializer();
const d = document;
const str = s.serializeToString(d);
saveXML(str);
このコードは、新しい XMLSerializer
オブジェクトを作成し、シリアライズされる Document
を serializeToString()
に渡します。これは、渡した文書と同等の XML を返します。
XML を基にした DOM にノードを挿入する
この例は、Element.insertAdjacentHTML()
メソッドを使用して新しい DOM Node
を Document
の body に挿入します。これは、Element
オブジェクトをシリアライズすることにより作成された XML を基にしています。
メモ: 実際は、importNode()
メソッドを呼び出して新しいノードを DOM に挿入する代わりに、以下のいずれかのメソッドを呼び出して DOM ツリーに追加することになるでしょう。
Element.append()
/Element.prepend()
およびDocument.append()
(en-US) /Document.prepend()
(en-US) メソッドElement.replaceWith()
メソッド(既存のノードを新しいノードと置き換えるため)Document.insertAdjacentElement()
およびElement.insertAdjacentElement()
メソッド
insertAdjacentHTML()
は文字列を受け入れるますが、2 番目の引数として Node
を受け入れないため、XMLSerializer
を使用して先にノードを文字列に変換します。
js
const inp = document.createElement("input");
const XMLS = new XMLSerializer();
const inp_xmls = XMLS.serializeToString(inp); // まず DOM ノードを文字列に変換
// 新たに作成されたノードを文書の body に挿入
document.body.insertAdjacentHTML("afterbegin", inp_xmls);
このコードは、Document.createElement()
を呼び出して新しい <input>
要素を作成し、serializeToString()
を使用して XML にシリアライズします。
完了したら、insertAdjacentHTML()
を使用して <input>
要素を DOM に挿入します。
仕様書
Specification |
---|
DOM Parsing and Serialization # the-xmlserializer-interface |
ブラウザーの互換性
BCD tables only load in the browser