XML CDATA概述

XML 文档中的所有文本均会被解析器解析。只有 CDATA 区段中的文本会被解析器忽略。

XML CDATA概述XML CDATA概述

PCDATA - 被解析的字符数据

XML 解析器通常会解析 XML 文档中所有的文本。

当某个 XML 元素被解析时,其标签之间的文本也会被解析:

<message>This text is also parsed</message>

解析器之所以这么做是因为 XML 元素可包含其他元素,就像这个实例中,其中的 <name> 元素包含着另外的两个元素(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 部分由 "<![CDATA[" 开始,由 "]]>" 结束:
在上面的实例中,解析器会忽略 CDATA 部分中的所有内容。

关于 CDATA 部分的注释:

CDATA 部分不能包含字符串 "]]>"。也不允许嵌套的 CDATA 部分。

标记 CDATA 部分结尾的 "]]>" 不能包含空格或换行。

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
XMLCDATA(字符数据)是一种特殊的语法结构,用于在XML文档中包含一些可能被XML解析器误解的文本数据。CDATA通常用于包含特殊字符(如小于号和大于号)、标记和其他保留字符等的文本。 在XML中,正常情况下,文本数据将被XML解析器解析并按照其规则进行处理。但是,如果我们希望将文本数据视为纯文本而不进行解析,就可以使用CDATACDATA会告诉XML解析器将其包含的文本数据视为纯字符数据,而不是XML标记。这样可以确保文本数据被正确显示而不引起解析错误。 CDATA以以下方式定义在XML文档中: <![CDATA[文本数据]]> 在CDATA内部,我们可以包含任何文本数据,包括特殊字符和XML标记。解析器会忽略CDATA标记内的任何XML标记,并将所有内容视为普通文本。这对于包含HTML代码或其他需要保留原始格式的内容非常有用。 例如,假设我们需要在XML文档中包含一段HTML代码: <description><![CDATA[<strong>Hello, World!</strong>]]></description> 如果我们不使用CDATA将HTML代码包装起来,XML解析器将尝试解析HTML标签,并将其视为XML标记,而不是纯粹的文本。但是使用CDATAXML解析器将始终将其视为文本,并正确显示HTML代码。 总之,CDATA是一种特殊的语法结构,用于在XML文档中包含可能被解析器误解的文本数据。它确保文本数据被正确显示而不引起解析错误,并且可以包含特殊字符、XML标记和其他保留字符。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值