XML与DTD(够用)

1: 概述

1.1 什么是XML

1.2 三个重点

1.3规则

1.4 常用转义

2: Xml声明

XML 中,空格会被保留

XML 以 LF 存储换行

3:Xml标签

4:Xml元素

5:XML 属性

6:验证XML

7:最佳命名习惯

8:XML进阶

1: 概述

1.1 什么是XML

XML指可扩展标记语言。它是从标准通用标记语言派生的基于文本的标记语言(SGML).

1.2 三个重点

XML是可扩展的: XML允许你创建自己的自描述性的标签,或语言,适合您的应用程序.

XML进行数据 : 不存在它:XML允许你无论存储将如何呈现这些数据.

XML是一个公共标准 : XML是由一个组织开发的名为万维网联盟(W3C),并可以作为一个开放的标准.

 1.3规则

基本语法:

1. xml文档的后缀名 .xml

2. xml第一行必须定义为文档声明

3. xml文档中有且仅有一个根标签

4. 属性值必须使用引号(单双都可)引起来

5. 标签必须正确关闭

6. xml标签名称区分大小写 (标签 属性)

         7. xml只允许只有一个根(Root)标签

         8. xml标签的属性也是区分大小写的

      1.4 常用转义

2: Xml声明

  xml分为两个部分, xml声明 xml标签

版本:

编码

是否依赖于信息从外部源,诸如外部的文档类型定义(DTD)的语法分析程序,其内容。默认值被设置为无。将其设置为yes告诉处理器有需要解析的文件没有外部声明

yes no

<?xml version=‘1.0‘ encoding=‘UTF-8‘ standalone=‘yes‘ ?>

xml注释:

<!-- -->

XML 中,空格会被保留

Hello           Tove   ====>转换为 Hello Tove

XML 以 LF 存储换行

在 Windows 应用程序中,换行通常以一对字符来存储:回车符(CR)和换行符(LF)。

在 Unix 和 Mac OSX 中,使用 LF 来存储新行。

3:Xml标签

完整闭合标签

<address>这是正确的句法</address>

空标签

<hr></hr> #或者 <hr/>

4:Xml元素

可以包含一个或者多个元素,这些元素允许两种不同的赋值方法

<?xml version="1.0" encoding="UTF-8"?> <note>  <to>Tove</to>  <from>Jani</from>  <heading>Reminder</heading>  <body>Don‘t forget me this weekend!</body> </note>

5:XML 属性

属性必须加引号

<person sex="female"> 或者这样也可以: <person sex=‘female‘>

多个属性

<person name="tom" sex="female">

尽量使用元素代替属性

属性不能包含多个值(元素可以)

属性不能包含树结构(元素可以)

属性不容易扩展(为未来的变化)

数据库中用于标识某个元组

使用id表示某一组数据

<?xml version="1.0" encoding="utf-8"?> <messages>  <note id="501">    <to>Tove</to>      <from>Jani</from>      <heading>Reminder</heading>      <body>Don‘t forget me this weekend!</body>  </note>   </messages>

6:验证XML

DTD验证

本地验证: <!DOCTYPE note SYSTEM "Note.dtd">

网络验证:<!DOCTYPE note PUBLIC "URL">

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE note SYSTEM "Note.dtd"> // 指定验证的文件 <note>  <to>Tove</to>    <from>Jani</from>    <heading>Reminder</heading>    <body>Don‘t forget me this weekend!</body> </note>

schema验证

XSD:描述

7:最佳命名习惯

使名称具有描述性。使用下划线的名称也很不错:<first_name>、<last_name>。

名称应简短和简单,比如:<book_title>,而不是:<the_title_of_the_book>。

避免 "-" 字符。如果您按照这样的方式进行命名:"first-name",一些软件会认为您想要从 first 里边减去 name。

避免 "." 字符。如果您按照这样的方式进行命名:"first.name",一些软件会认为 "name" 是对象 "first" 的属性。

避免 ":" 字符。冒号会被转换为命名空间来使用(稍后介绍)。

 显示XML

使用CSS

使用XLAT

 8:XML进阶

XML命名空间

xmlns:f="http://www.w3cschool.cc/furniture"   f就是指定的命名空间

Android中 布局标签就是使用的这种命名空间

CDATA数据

   对于某些数据需要直接按照文本形式处理的 如@lt @gt 就不会处理

<![CDATA[ if (a < b && a < 0) then 具体数据  ]]>

XML 数据岛

XML 数据岛是嵌入到 HTML 页面中的 XML 数据。

XML 数据岛只在 Internet Explorer 浏览器中有效。

1: 基本使用

2:声明元素

3 xml属性

4:xml实体

 定义:  文档类型定义(DTD)可定义合法的XML文档构建模块。它使用一系列合法的元素来定义文档的结构。

 PCDATA:

PCDATA 的意思是被解析的字符数据(parsed character data)。

可把字符数据想象为 XML 元素的开始标签与结束标签之间的文本。

PCDATA 是会被解析器解析的文本。这些文本将被解析器检查实体以及标记。

 CDATA:

CDATA 是不会被解析器解析的文本。在这些文本中的标签不会被当作标记来对待,其中的实体也不会被展开。

 XML外部 内部:

<!DOCTYPE tglib SYSTEM "URL|本地路径">

<!DOCTYOE tglib PUBLICK "URL"> // 声明为公共的DTD文件

1: 基本使用

声明DTD开始部分

<!DOCTYPE DTDNAME [    <!-- 具体的元素 属性 实体--> ]>

2:声明元素

 空元素

<! ELEMENT name EMPTY> # 实例 <!ELEMENT br EMPTY> <by/>

     多个元素

含有多个元素的元素,子元素必须连续声明

<!ELEMENT name (att1,att2) # 实例 <!ELEMENT note (to,from,heading,body)> <!ELEMENT to (#PCDATA)> <!ELEMENT from (#PCDATA)> <!ELEMENT heading (#PCDATA)> <!ELEMENT body (#PCDATA)>

    PCDATA元素(可以被解析为元素的)

<!ELEMENT name (#PCDATA)> # 实例 <!ELEMENT body (#PCDATA)>

    带有任何内容的元素

<!ELEMENT name ANY> # 实例 <!ELEMENT body ANY>

 声明只出现一次的元素

<!ELEMENT element-name (child-name)> # 实例: <!ELEMENT note (message)>

声明最少出现一次的元素 +

<!ELEMENT element-name (child-name+)> # 实例: <!ELEMENT note (message+)>

声明出现零次或多次的元素 *

<!ELEMENT element-name (child-name*)> # 实例: <!ELEMENT note (message*)>

声明出现零次或一次的元素 ?

<!ELEMENT element-name (child-name?)> # 实例: <!ELEMENT note (message?)>

声明 |可选内容

实例: <!ELEMENT note (message|body)>

声明混合型的内容

实例: <!ELEMENT note (#PCDATA|to|from|header|message)*>

3 xml属性

    格式

<!ATTLIST elename attname type value> #          元素名  属性名   类型  属性值 # 实例 <!ATTLIST User name CDATA  " "> # 这个" " 可以不给 可以给限定值 #REQUIRED #FIXED #IMPLIED

    提供的类型


类型


描述


CDATA


值为字符数据 (character data)


(en1|en2|..)


此值是枚举列表中的一个值


ID


值为唯一的 id


IDREF


值为另外一个元素的 id


IDREFS


值为其他 id 的列表


NMTOKEN


值为合法的 XML 名称


NMTOKENS


值为合法的 XML 名称的列表


ENTITY


值是一个实体


ENTITIES


值是一个实体列表


NOTATION


此值是符号的名称


xml:


值是一个预定义的 XML 值

提供的属性



解释



属性的默认值


#REQUIRED


属性值是必需的


#IMPLIED


属性不是必需的


#FIXED value


属性值是固定的

   

    完整例子

<!ELEMENT Address EMPTY> <!ATTLIST Address street CDATA "" > # 应用 <Address street="幸福大街" />

     强制要求值 可选 固定值

<!ELEMENT Address EMPTY> <!ATTLIST Address street CDATA #REQUIRED > //那street 这个属性必须给出 # 实例 <Address street=‘xxx‘/> <!ATTLIST Address street CDATA #FIXED "必须给出固定的值"> // <!ATTLIST Address street CDATA #IMPLIED > //可选

列举属性值

DTD: <!ATTLIST payment type (check|cash) "cash"> # XML 例子: <payment type="check" /> 或 <payment type="cash" />

    指定ID IDREF

<!ATTLIST User id ID #REQUIRED > // # <User id="101"/> <!ATTLIST User2 id IDREF #REQUIRED> <User2 id="101"> // 引用别人的ID值 <User2 id="101 102 103"> // 表示引用多个ID值

4:xml实体

  定义

<!ENTITY entity-name value> # 实例 <!ENTITY name1  "tom"> <!ENTITY name2  "gory"> # 应用 <author>@name1;@name2</author>

5 一些题目

根据上面的内容写出DTD约束文件

<?xml version=‘1.0‘ encoding=‘utf-8‘?>
<!DOCTYPE Teams {
    <!ELEMENT Teams (Team+)/>
    <!ELEMENT Team (#PCDATA)/>
    <!ELEMENT Team (Teamname,Country,Member+)/>
    <!ELEMENT Teamname (#PCDATA)/>
    <!ELEMENT Country (#PCDATA)/>
    <!ELEMENT Member (#PCDATA)/>
    <!ATTLIST Member Name CDATA #REQUIRED/>
    <!ATTLIST Member Age CDATA #REQUIRED />
    <!ATTLIST Member Sex CDATA (Female|Male) "Male"/>
]>
<Teams>
    <Team>
        <Teamname>Roma</Teamname>
        <Country>Italy</Country>
        <Member Name=”AAA ”Age="36" Sex="Male" />
        <Member Name=”BBB ”Age="26" Sex="Female" />
    </Team>
</Teams>

原文地址:https://www.cnblogs.com/dgwblog/p/11832006.html

时间: 2024-10-08 03:50:59

XML与DTD(够用)的相关文章

理清XML,HTML,DTD,Schema,户阿由

其实我是很厉害的段子手,吹逼高手.很久很久以前,有一次,在那个那个地方...(啪)卢本伟闭嘴==! 1.HTML和XML没啥关系,XML和DTD,Schema比较亲近. 2.HTML是显示数据.XML是传输存储数据.(至于定义什么的自己去搜着看,我主要是了解他们干嘛的.) 3.DTD是一种语法规则,它用来规则XML文档怎么怎么写. 4.Schema就牛逼了,基于XML,只是功能比DTD更丰富,但是最最根本的目标,和DTD一样,为了让XML更方便写,传输存储处理数据上功能更强大. 5.DTD和Sc

jdom dom4j解析xml不对dtd doctype进行验证(转)

一.写在所有之前:因为dom4j和jdom在这个问题上处理的方法是一模一样的,只是一个是SAXBuilder 一个SAXReader,这里以jdom距离,至于dom4j只需要同理替换一下就可以了.二.问题发生的情况当你用jdom读取一个有dtd验证的xml文件,同时你的网络是不通的情况下.会出现以下错误:1,代码如下 package dom;import java.io.File;import org.jdom.Document;import org.jdom.input.SAXBuilder;

【PHP XML与dtd概述【完整版】】

一.XML文件简介 关于XML的大多数人都知道一些,HTML->xhtml->xml,这个顺序本来应当是HTML发展的顺序. XML可以当做配置文件使用,还可以充当小型的数据库. version:文档符合xml1.0规范,我们学习的一般都是1.0encoding:文档字符编码,比如gb2312,一般使用utf-8standalone:文档定义是否独立使用standalone="yes",表名文档独立使用standalone="no":默认 XML文档有且

xml约束DTD演示

此演示xml和DTD在一个文件中 book.xml <?xml version="1.0" encoding="utf-8"?> <!DOCTYPE 书架 [ <!ELEMENT 书架 (书+)> <!ELEMENT 书 (书名,作者,售价)> <!ELEMENT 书名 (#PCDATA)> <!ELEMENT 作者 (#PCDATA)> <!ELEMENT 售价 (#PCDATA)> &

XML之DTD(2)

接上一篇<XML之DTD(1)>        DTD实体       实体是用于定义引用普通文本或特殊字符的快捷方式的变量. 实体引用是对实体的引用. 实体可在内部或外部进行声明. 一个内部实体声明:          语法: <!ENTITY 实体名称 "实体的值"> DTD例子: <!ENTITY writer "Bill Gates"> <!ENTITY copyright "Copyright W3Sch

javaee之xml和dtd的基础练习

从昨天的学习中,我学习到了xml的基础知识,包括dtd的约束基础 一.首先 是关于dtd的联系,关于这部分我们知识需要了解能够根据dtd约束来写出xml文件即可 1)首先是dtd文件: <!ELEMENT TVSCHEDULE (CHANNEL+)> <!ELEMENT CHANNEL (BANNER,DAY+)> <!ELEMENT BANNER (#PCDATA)> <!ELEMENT DAY (DATE,(HOLIDAY|PROGRAMSLOT+)+)>

XML的DTD和Schema约束

为什么要使用约束? XML是自定义的标签,有时候标签太多,记不住,所以就需要有约束来告诉我能写哪些标签,哪些标签写错了不能识别 XML中有哪几种约束? 有很多约束,其中DTD和Schema约束最为常见. 约束本质上是什么? 约束本质上也是一种xml文件. DTD约束和Schema约束的区别 特点的区别: DTD约束较为古老,简单,一些老框架使用DTD作为约束:Struts2和Hibernate都使用DTD作为其XML配置文件的约束 Schema约束功能更为强大,用的更为广泛,Tomcat和Spr

二、XML的DTD和Schema

  1.DTD简单介绍   2.schema入门 schema出现的目的是通过一个更加合理的方式来编写xml的限制文件(基于xml语法的方式) schema可以使用命名空间来支持多个名称相同的元素 schema可以很好的完成对java或者所有对象的修饰并且提供了大量的数据类型     2.1.命名空间 在xml中引入schema 通过文件路径引入     2.2.元素和属性     2.3.相关约束   3.深入schema     3.1.数据模型的创建     3.2.相关的设计方案    

javaweb学习总结八(xml约束&lt;DTD以及schema&gt;)

一:XML约束概念 xml约束:可以编写一个文档来约束xml文件的书写规范. xml语言格式比较严谨,不可能让程序员随意编写,所以必须要有约束. 二:常用的xml约束技术 1:DTD,document type definition 2:校验xml文件正当性 a:使用解析工具 b:使用ide工具,如:eclipse books.html 1 <?xml version="1.0" ?> 2 <!DOCTYPE bookstore SYSTEM "book.d