欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【XML入门教程:XML CDATA】,下面是详细的分享!
XML入门教程:XML CDATA
所有XML文档中的文本均会被解析器解析。
只有CDATA区段(CDATA section)中的文本会被解析器忽略。
Parsed 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个预定义的实体引用:
< < 小于
> > 大于
& & 和号
' ' 省略号
" " 引号
注释:严格地讲,在XML中仅有字符"<"和"&"是非法的。省略号、引号和大于号是合法的,但是把它们替换为实体引用是个好的习惯。
CDATA
CDATA内部的所有东西都会被解析器忽略。
假如您的文本中包含了大量的"<"和"&"字符 - 就像编程代码中经常出现的情况一样 - 那么这个XML元素就可以被定义为一个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区段的嵌入是不被允许的。
同时也需要确保在"]]>"字符串中没有空格或折行。
以上所分享的是关于XML入门教程:XML CDATA,下面是编辑为你推荐的有价值的用户互动:
相关问题:xml关于cdata的问题
答:简单的说,因为元素内容有在XML中不合法的字符(这里是&),不能直接写,要么就将其转义(&要写成& amp ; ),要么就用CDATA段将其包含在内,这样就合法了。 你可以试着将去掉,则xml文件将会出错。 CDATA定义如下: 术语 CDATA 指的是不应由 XML... >>详细
相关问题:怎么解析带 ![CDATA[产品查询成功!]] 格式的xml文件
答:你是用什么来解析啊? 不管是哪种DOM解析,cdata都是透明的,也就是完全可以当做cdata不存在来解析,所以 ![CDATA[产品查询成功!]] 只是在生成的时候需要特殊的代码,而它解析时其实和 产品查询成功! 的解析方法是一样的。 >>详细
相关问题:XML文件里面的CDATA是什么 有什么作用
答:显示一段文字 如果是只有文字 就不会有异常,如果内部还含有其他元素呢,比如内部包含了first和last两个元素:显示一段文字 那么解析以后的结果xml就会理解成:显示一段文字如果在XML文档中使用类似" & 字符是不能直接存入XML的,需要转义,而用这... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
