files/en-us/web/api/document/createcdatasection/index.md
{{APIRef("DOM")}}
createCDATASection() creates a new CDATA section node,
and returns it.
createCDATASection(data)
data
A CDATA Section node.
const doc = new DOMParser().parseFromString("<xml></xml>", "application/xml");
const cdata = doc.createCDATASection("Some <CDATA> data & then some");
doc.querySelector("xml").appendChild(cdata);
console.log(new XMLSerializer().serializeToString(doc));
// Displays: <xml><![CDATA[Some <CDATA> data & then some]]></xml>
NOT_SUPPORTED_ERR.NS_ERROR_DOM_INVALID_CHARACTER_ERR exception if one tries
to submit the closing CDATA sequence (]]>) as part of the data, so
unescaped user-provided data cannot be safely used without this method getting this
exception ({{domxref("document.createTextNode","createTextNode()")}} can often be used
in its place).{{Specifications}}
{{Compat}}