CDATA标签的用法

术语 CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)。
在xml中英文问号“?”是可以被正常解析的,但是以下这几种符号是不能正常解析的:分别是“&”、“<”、“>”、“’”、“"”。
“<” 会产生错误,因为解析器会把该字符解释为新元素的开始。
“&” 也会产生错误,因为解析器会把该字符解释为字符实体的开始。

解决方法一:
把实体引用编码后使用,即

把“&” 编码为 “&amp;” 
把“<” 编码为“&lt;” 
把“>” 编码为 “&gt;” 
把“'” 编码为 “&apos;” 
把“"” 编码为 “&quot;” 

解决方法二:使用<![CDATA[ sql 语句 ]]>
某些文本,比如 JavaScript 代码,包含大量 “<” 或 “&” 字符。为了避免错误,可以将脚本代码定义为 CDATA。
CDATA 部分中的所有内容都会被解析器忽略。CDATA 部分由 "<![CDATA[" 开始,由 "]]>" 结束。
在mapper文件中写sql语句时,遇到特殊字符时,如:< 等,建议使用
<![CDATA[ sql 语句 ]]>标记,将sql语句包裹住,不被解析器解析

小例子:

<![CDATA[function matchwo(a,b){if (a < b && a < 0) then { return 1; }else { return 0; }}]]>
  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
XML的CDATA(字符数据)是一种特殊的语法结构,用于在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标记和其他保留字符。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值