区分XML中CDATA和#PCDATA

在XML文档中, 能看到“CDATA"的地方有三处: 

1)在DTD中,指定标签中某个属性的类型为字符型时,使用CDATA。由于XML解析器回去分析这段字符内容,于是里面若是须要使用>, <, &, ', "这5个特殊字符,应当用对应的替代替代字符来表示(必须以&开始,以;结束)。具体以下: 
< - &lt;  (less than) 
> - &gt;  (greater than) 
& - &amp;  (ampersand) 
' - &apos;  (apostrophe) 
" - &quot;  (straight double quotation mark) 

例如在DTD中声明: 
    <!ATTLIST author period CDATA> 它表示在author这个标签中,period属性应该是字符类型。 


2) 在XML中,指定某段内容没必要被XML解析器解析时,使用<![CDATA[...]]>。也就是说中括号中的内容解析器不会去分析。因此其中能够包含>, <, &, ', "这5个特殊字符。常常把一段程序代码嵌入到<![DATA[...]]>中。 由于代码中可能包含大量的 >, <, &, "这样的特殊字符。 

例如在XML中声明: 
    <![CDATA[ 
        if(i<10){ 
          System.out.println("i<10"); 
        } 
    ]]> 

3) 在DTD中,指定某个标签中的内容是字符数据时,使用(#PCDATA)。因为它的内容也是须要解析器来解析的,全部仍然须要转换>, <, &, ', "这5个特殊字符。 

例如在DTD中声明: 
    <!ELEMENT name (#PCDATA)> 它表示在<name>和</name>标签之间能够插入字符或者子标签。
 
#PCDATA是要给XML解析的数据,如 > 要写成 &gt;才不会出错。 
CDATA区域表示里面是什么数据XML不会解析。
 
【XML中CDATA与#PCDATA与PACATA的区别】
 

1. CDATA: Character Data, PCDATA: Parsableless

CDATA,是能够分析的字符序列,CDATA就是指字符串,而PCDATA能够是字符串、子元素、字符串和子元素。  post

2. CDATA是属性声明中的类型,就是字符串,&、<、“”和‘’ 等都具备特殊含义被解析,例如:"解析为双引号;#PCDATA是元素声明中的类型,指的是混合类型,便可以包子元素也可包含字符串, &和<也是具备特殊含义被解析。 blog

ANY 并不局限于“#PCDATA”,只是说明该元素能够包含任何内容,通常来说,解析器没法验证其有效性(通常也不会验证),#PCDATA源于“可解析的字符”,对于有特殊含于的< 会按照子元素开始进行解析。文档

#PCDATA    该内容模型说明元素中能够同时出现文本和元素.
ANY           ANY关键子代表DTD中声明的任何元素均可以使用做该元素的子元素
CDATA       属性值是字符数据字符串

#PCDATA和ANY用于元素声明
CDATA用于属性声明io

相关文章
相关标签/搜索