XML中的CDATA标签的作用

分类专栏:
Java自学

文章标签:
Java自学
转载

XML中的CDATA标签的作用

1.XML 文档中的所有文本均会被解析器解析。只有 CDATA 区段中的文本会被解析器忽略。 2.PCDATA - 被解析的字符数据 XML 解析器通常会解析 XML 文档中所有的文本。当某个 XML 元素被解析时,其标签之间的文本也会被解析:

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

3.CDATA - (未解析)字符数据 术语 CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)。

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

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

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

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

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

CDATA 部分由 “” 结束:

<!--根据用户注册时间来查询,开始时间,结束时间-->
<select id="getUserByRegisterTime" parameterType="java.util.Map" resultMap="userMap">
    方法一:使用字符实体代替 大于符号>(&gt;) 小于符号<(&lt;) &符号(&amp;)            
    SELECT * FROM t_user WHERE 
    registration_time &gt;= #{begin} and registration_time &lt;= #{end}
    
    当然方法一的这种方式不够见名知意,于是采用方法二会得到大多数人的理解。
                                         
    方法二:使用<![CDATA[]]>
    <![CDATA[
      SELECT * FROM t_user WHERE 
	  registration_time >= #{begin} and registration_time <= #{end}
	]]>
</select>

有关字符实体的网址:https://www.w3school.com.cn/html/html_entities.asp

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

关于 CDATA 部分的注释: CDATA 部分不能包含字符串 “]]>”。也不允许嵌套的 CDATA 部分。

标记 CDATA 部分结尾的 “]]>” 不能包含空格或折行。

  • 作者:潘震
  • 评论

    留言