XML CDATA

XML 文档中的所有文本均会被解析器解析。
当某个 XML 元素被解析时,其标签之间的文本也会被解析:
因为 XML 元素可包含其他元素,就像这个实例中,其中的 元素包含着另外的两个元素(first 和 last):

<name><first>Bill</first><last>Gates</last></name>

而解析器会把它分解为像这样的子元素:

<name>
<first>Bill</first>
<last>Gates</last>
</name>

解析字符数据(PCDATA)是 XML 解析器解析的文本数据使用的一个术语。


只有 CDATA 区段中的文本会被解析器忽略。
术语 CDATA 是不应该由 XML 解析器解析的文本数据。

像 "<" 和 "&" 字符在 XML 元素中都是非法的。

"<" 会产生错误,因为解析器会把该字符解释为新元素的开始。

"&" 会产生错误,因为解析器会把该字符解释为字符实体的开始。

某些文本,比如 JavaScript 代码,包含大量 "<" 或 "&" 字符。为了避免错误,可以将脚本代码定义为 CDATA。

CDATA 部分中的所有内容都会被解析器忽略。

CDATA 部分由 "" 结束:

<script>
<![CDATA[
function matchwo(a,b)
{
if (a < b && a < 0) then
{
return 1;
}
else
{
return 0;
}
}
]]>
</script>

在上面的实例中,解析器会忽略 CDATA 部分中的所有内容。

关于 CDATA 部分的注释:
  1. CDATA 部分不能包含字符串 "]]>"。也不允许嵌套的 CDATA 部分。
  2. 标记 CDATA 部分结尾的 "]]>" 不能包含空格或换行。

文章来源:XML CDATA | 菜鸟教程

posted @ 2021-04-14 11:36  张三丰学Java  阅读(145)  评论(0编辑  收藏  举报