XML中的转义字符和CDATA表示
2011-12-01 12:46
183 查看
XML CDATA
Previous PageNext Page
所有 XML 文档中的文本均会被解析器解析。
只有 CDATA 区段(CDATA section)中的文本会被解析器忽略。
PCDATA
PCDATA 指的是被解析的字符数据(Parsed Character Data)。XML 解析器通常会解析 XML 文档中所有的文本。
当某个 XML 元素被解析时,其标签之间的文本也会被解析:
<message>此文本也会被解析</message>
解析器之所以这么做是因为 XML 元素可包含其他元素,就像这个例子中,其中的 <name> 元素包含着另外的两个元素(first 和 last):
<name><first>Bill</first><last>Gates</last></name>
而解析器会把它分解为像这样的子元素:
<name> <first>Bill</first> <last>Gates</last> </name>
转义字符
非法的 XML 字符必须被替换为实体引用(entity reference)。假如您在 XML 文档中放置了一个类似 "<" 字符,那么这个文档会产生一个错误,这是因为解析器会把它解释为新元素的开始。因此你不能这样写:
<message>if salary < 1000 then</message>
为了避免此类错误,需要把字符 "<" 替换为实体引用,就像这样:
<message>if salary < 1000 then</message>
在 XML 中有 5 个预定义的实体引用:
< | < | 小于 |
> | > | 大于 |
& | & | 和号 |
' | ' | 省略号 |
" | " | 引号 |
CDATA
术语 CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)。在 XML 元素中,"<" 和 "&" 是非法的。
"<" 会产生错误,因为解析器会把该字符解释为新元素的开始。
"&" 也会产生错误,因为解析器会把该字符解释为字符实体的开始。
某些文本,比如 JavaScript 代码,包含大量 "<" 或 "&" 字符。为了避免错误,可以将脚本代码定义为 CDATA。
CDATA 部分中的所有内容都会被解析器忽略。
CDATA 部分由 "<![CDATA[" 开始,由 "]]>" 结束:
<script> <![CDATA[ function matchwo(a,b) { if (a < b && a < 0) then { return 1; } else { return 0; } } ]]> </script>
在上面的例子中,解析器会忽略 CDATA 部分中的所有内容。
关于 CDATA 部分的注释:
CDATA 部分不能包含字符串 "]]>"。也不允许嵌套的 CDATA 部分。标记 CDATA 部分结尾的 "]]>" 不能包含空格或折行。
相关文章推荐
- XML中的转义字符和CDATA表示
- XML中的转义字符和CDATA表示
- xml中的<![CDATA[]]>和转义字符
- XML中的转义字符和CDATA部件
- XML CDATA的有关说明
- Android常见XML转义字符(总结)
- Element 对象表示 XML 文档中的元素。
- SpringMVC收发带CDATA的xml报文
- android string.xml里空格表示
- XML 中的 ﹤![CDATA[ ]]>,及其解析
- 关于<![CDATA[]]>在xml中的含义
- 每当数据中有'<'、'&'等特殊字符时,封装的XML就无法解析,CDATA属性帮了大忙
- Android strings.xml中空格符的标识步骤附xml特殊字符表示法
- 区分XML中CDATA和#PCDATA
- 使用<![CDATA[ ]]> 标识 使内容不被XML解析
- <![CDATA[]]>和转义字符
- XML和HTML常用转义字符
- XML和HTML常用转义字符
- C#如何使用转义字符来正确的表示双引号、单引号等字符串
- Android string.xml如何输入空格、换行等符号——转义字符