深入解析XML中的字符实体与字符数据
字符实体
在我们了解字符实体之前,先了解一下什么是 XML 实体。
W3 联盟 对实体的定义:文档实体作为实体树的根元素和 XML 处理程序的起点。
这意味着实体就是 XML 中的占位符。它们可以声明在文档序言或者DTD中。实体有不同的类型,本章后面会讨论字符实体。
HTML 和 XML 都有一些符号被保留使用,它们不能在 XML 代码中用作内容。例如,< 和 > 符号被用作 XML 标签的开头和结尾。要显示这些特殊字符,就要使用字符实体。
有些特殊的字符或符号还不能直接使用键盘输入。可以使用字符实体来显示这些符号或特殊字符。
字符实体类型
有三种类型的字符实体:
预定义的字符实体。
编码字符实体。
命名字符实体。
预定义的字符实体
引入它们是为了避免使用某些有歧义的符号。例如,当我们把小于(<)或大于(>)符号当尖括号(<>)使用时就会产生歧义。字符实体从根本上来说就是用来界定 XML 标签的。下面是一个来自 XML 规范的预定义字符实体列表。它们可以用来表示某些字符而不带歧义。
和号: &
单引号: '
大于: >
小于: <
双引号: "
数字字符实体
数字引用被用来表示字符实体。数字引用可以是十进制或十六进制格式。由于有数以千记的数字引用,导致很难记住它们。数字引用通过使用字符在 Unicode 字符集中的编码数值来表示。
十进制数字引用基本语法:
- &# decimal number ;
十六进制数字引用基本语法:
- &#x Hexadecimal number ;
下面的表格列出了一些预定义字符实体和它们对应的数值:
实体名称 | 字符 | 十进制引用 | 十六进制引用 |
---|---|---|---|
quot | " | " | " |
amp | & | & | & |
apos | ' | ' | ' |
lt | < | < | |
gt | > | > | > |
命名字符实体
正如上面所说的,数值字符很难记住,最受欢迎的字符实体类型是命名字符实体。因为每个实体都用一个名称标识。
例如:
'Aacute' 表示带重音符的大写 A 字符。
'ugrave' 表示带沉音符的小写 u。
CDATA 片段
术语 CDATA 就是字符数据。CDATA 被定义为不由解析器解析的文本块,但它被公认为标记。
标记中预定义的实体比如 <,> 和 & 需要手动输入并且通常难以阅读。这种情况下就可以使用 CDATA 片段。通过使用 CDATA 片段,我们可以告诉解析器文档的特定部分不包含标记,应该被当做普通文本对待。
语法
下面是 CDATA 片段的语法:
- <![CDATA[
- characters with markup
- ]]>
上面的语法由三个部分组成:
CDATA 开始部分 - CDATA 以9个字符的分隔符<![CDATA[开头。
CDATA 结束部分 - CDATA 以 ]]> 分隔符结尾。
CData 部分 - 上面这两个标记之间的字符被解释为字符而不是标记。这个部分可以包含标记字符(<,> 和 &),但是它们会被 XML 处理程序忽略。
示例
下面的标记代码展示了 CDATA。其中写在 CDATA 片段中的字符都会被解析器忽略。
- <script>
- <![CDATA[
- <message> Welcome to TutorialsPoint </message>
- ]] >
- </script>
在上述的语法中,<message> 和 </message> 之间的所有内容都会被当做字符数据而不是标记。
CDATA 规则
XML CDATA 需要遵循以下规则:
XML 文档任何位置的 CDATA 都不能包含 "]]>" 字符。
CDATA 片段不可以嵌套。
相关文章
- 这篇文章主要介绍了详解XML中的代码注释书写方法,文章中总结了注释使用的一些注意点,比如XML不支持嵌套注释等,需要的朋友可以参考下2016-02-14
- 这篇文章主要介绍了XML中的属性学习教程,包括使用属性将数据存储在子元素中的例子,需要的朋友可以参考下2016-02-14
- 这篇文章主要介绍了XML中的标签与元素的使用,是XML入门学习中的基础知识,需要的朋友可以参考下2016-02-14
- 这篇文章主要介绍了XML中的文档与声明用法,是XML入门学习中的基础知识,需要的朋友可以参考下2016-02-04
- 这篇文章主要介绍了XML标记语言的基本概念及语法入门教程,XML同时也被广泛用作标记数据来作为XML数据交换格式,需要的朋友可以参考下2016-02-04
- WPS2016文档怎么保存为XML格式?wps默认的伯村格式是.doc,但是有的时候,必须使用xml格式的文件,该怎么把WPS的doc格式另存为xml格式呢?下面我们来看看详细教程2015-11-05
- 这篇文章主要为大家介绍了批量导入XML数据到drupal系统的方法,主要通过一个XML文件导入类来实现这一功能,是非常实用的技巧,需要的朋友可以参考下2014-11-10
- 这是一款基于flash+xml实现的3D层叠样式叠加切换特效源码,并配以韩国网页风格的图片。整体图片切换效果流畅自然,中间显示清晰的图片,其他图片模糊显示,还可通过鼠标点2014-09-03
- 这篇文章主要介绍了wordpress非插件实现xml格式网站地图,需要的朋友可以参考下2014-08-03
最新评论