Une section CDATA est " une section de contenu d'élément qui est marquée pour que l'analyseur interprète comme uniquement des données de caractères, pas de balisage. "
Syntaxiquement, il se comporte de manière similaire à un commentaire:
<exampleOfAComment>
<!--
Since this is a comment
I can use all sorts of reserved characters
like > < " and &
or write things like
<foo></bar>
but my document is still well-formed!
-->
</exampleOfAComment>
... mais cela fait toujours partie du document:
<exampleOfACDATA>
<![CDATA[
Since this is a CDATA section
I can use all sorts of reserved characters
like > < " and &
or write things like
<foo></bar>
but my document is still well formed!
]]>
</exampleOfACDATA>
Essayez d'enregistrer ce qui suit en tant que .xhtml
fichier ( pas .html
) et ouvrez-le à l'aide de FireFox ( pas Internet Explorer ) pour voir la différence entre le commentaire et la section CDATA; le commentaire n'apparaîtra pas lorsque vous regardez le document dans un navigateur, tandis que la section CDATA:
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en" >
<head>
<title>CDATA Example</title>
</head>
<body>
<h2>Using a Comment</h2>
<div id="commentExample">
<!--
You won't see this in the document
and can use reserved characters like
< > & "
-->
</div>
<h2>Using a CDATA Section</h2>
<div id="cdataExample">
<![CDATA[
You will see this in the document
and can use reserved characters like
< > & "
]]>
</div>
</body>
</html>
Quelque chose à noter avec les sections CDATA est qu'elles n'ont pas d'encodage, donc il n'y a aucun moyen d'y inclure la chaîne ]]>
. Toutes les données de caractères qui contiennent ]]>
devront - pour autant que je sache - être un nœud de texte à la place. De même, du point de vue de la manipulation DOM, vous ne pouvez pas créer une section CDATA qui comprend ]]>
:
var myEl = xmlDoc.getElementById("cdata-wrapper");
myEl.appendChild(xmlDoc.createCDATASection("This section cannot contain ]]>"));
Ce code de manipulation DOM va lever une exception (dans Firefox) ou entraîner un document XML mal structuré: http://jsfiddle.net/9NNHA/