XML 轻松学习手册(比较不错)第3/3页
程序员文章站
2022-06-28 16:37:09
我想就我个人学习过程的心得和经验,写一篇比较全面的介绍文章。首先有两点是需要肯定的: 第一:xml肯定是未来的发展趋势,不论是网页设计师还是网络程序员,都应该及时学习和了解...
我想就我个人学习过程的心得和经验,写一篇比较全面的介绍文章。
首先有两点是需要肯定的:
第一:xml肯定是未来的发展趋势,不论是网页设计师还是网络程序员,都应该及时学习和了解,等待只会让你失去机会;
第二:新知识肯定会有很多新概念,尝试理解和接受,您才可能提高。不要害怕和逃避,毕竟我们还年轻。
提纲
本文共分五大部分。分别是xml快速入门,xml的概念,xml的术语,xml的实现,xml的实例分析。最后附录介绍了xml的相关资源。作者站在普通网页设计人员的角度,用平实生动的语言,向您讲述xml的方方面面,帮助你拨开xml的神秘面纱,快速步入xml的新领域。
xml初学者普遍存在的问题
1。xml是什么?(不要说是可扩展的标记语言之类的话)
2。xml可以做什么?怎么做?(不需要回答,只需要列举出一个简单的例子即可)
1: xml,是用来描迷数据的.
2:举一个例子说明:有a数据库 b数据库,他们之间的标准不同,不能互传.那么你可以把数据放在xml中,而后就可以让a,b之间可以共同传输数据了.
补充:
首先要有一个概念,你最好不要去用xml设计网页,不是说不可以, 只是要说明,xml不是html的替代.
有了这个概念,就不会有很多的看完一个一个的教程,还不知道xml做什么,很明了
xml就是为了描述数据
开始学习xml:
1.工具:xmlspy2005,
2.学习xml从那里开始?
即我要说明的是:先写xml还是先写dtd或是xml schemas.
大多的教程从xml说起,再说dtd...再说xml schemas...
不过我个人觉的,先了解一下xml的基本语法,而后跳过dtd,从schemas开始.
这样不会让dtd搞的没兴趣..而后再对dtd作一定了解.这里要说明,我觉的先写
好一个schemas再写xml比较好.即,先建立模型.再去填数据.
第一章:xml快速入门
一. 什么是xml?
二. xml是新概念吗?
三. 使用xml有什么好处?
四. xml很难学吗?
五. xml和html的区别
六. xml的严格格式
七. 关于xml的更多
一. 什么是xml?
这往往是第一个问题,也往往在第一个问题上你就会搞不明白,因为大多的教材上这样回答:
xml是extensible markup language的简写,一种扩展性标识语言。 这是标准的定义。那么什么是标志语言,为什么叫扩展性?已经让人有些糊涂。我想我们这样来理解会好一些:
对html你已经非常熟悉了吧,它就是一种标记语言,记得它的全称吗:"hypertext markup language" 超文本标记语言。明白了?同时,html里面有很多标签,类似,等,都是在html
4.0里规范和定义,而xml里允许你自己创建这样的标签,所以叫做可扩展性。
这里有几个容易混淆的概念要提醒大家:
1.xml并不是标记语言。它只是用来创造标记语言(比如html)的元语言。天,又糊涂了!不要紧,你只要知道这一点:xml和html是不一样的,它的用处途比html广泛得多,我们将在后面仔细介绍。
2.xml并不是html的替代产品。xml不是html的升级,它只是html的补充,为html扩展更多功能。我们仍将在较长的一段时间里继续使用html。(但值得注意的是html的升级版本xhtml的确正在向适应xml靠拢。)
3.不能用xml来直接写网页。即便是包含了xml数据,依然要转换成html格式才能在浏览器上显示。
下面就是一段xml示例文档(例1),用来表示本文的信息:
<myfile>
<title>xml quick start</title>
<author>ajie</author>
<email>ajie@aolhoo.com</email>
<date>20010115</date>
</myfile>
注意:
1.这段代码仅仅是代码,让你初步感性认识一下xml,并不能实现什么具体应用;
2.其中类似< title>,< author>的语句就是自己创建的标记(tags),它们和html标记不一样,例如这里的< title>是文章标题的意思,html里的< title>是页面标题。
二. xml是新概念吗?
不是。xml来源于sgml,一种比html更早的标志语言标准。
关于sgml,我们来简单了解一下,你只需要有个大致概念就可以。
sgml全称是"standard generalized markup language"(通用标识语言标准)。看名称就知道:它是标志语言的标准,也就是说所有标志语言都是依照sgml制定的,当然包括html。sgml的覆盖面很广,凡是有一定格式的文件都属于sgml,比如报告,乐谱等等,html是sgml在网络上最常见的文件格式。因此,人们戏称sgml是html的"妈妈"。
而xml就是sgml的简化版,只不过省略了其中复杂和不常用的部分。(哦,明白了!是html第二个"mother",难怪比html功能强大呢。),和sgml一样,xml也可以应用在金融,科研等各个领域,我们这里讲的,只是xml在web方面的运用而已。
到这里,你应该有点明白了:xml是用来创建定义类似html的标记语言,然后再用这个标记语言来显示信息。 三. 使用xml有什么好处?
有了html,为什么还需要用xml?
因为现在网络应用越来越广泛,仅仅靠html单一文件类型来处理千变万化的文档和数据已经力不丛心,而且html本身语法十分不严密,严重影响网络信息传送和共享。(想想浏览器兼容的问题伤透多少设计师的脑细胞啊。)人们早已经开始探讨用什么方法来满足网络上各种应用的需要。使用sgml是可以的,但sgml太庞大,编程复杂,于是最终选择了"减肥"的sgml---xml作为下一代web运用的数据传输和交互的工具。
使用xml有什么好处?来看w3c组织(xml标准制定者)的说明:
xml使得在网络上使用sgml语言更加"简单和直接": 简化了定义文件类型的过程,简化了编程和处理sgml文件的过程,简化了在web上的传送和共享。
1.xml可以广泛的运用于web的任何地方;
2.xml可以满足网络应用的需求;
3.使用xml将使编程更加简单;
4.xml便于学习和创建;
5.xml代码将清晰和便于阅读理解;
还是抽象了些。让我们在后面的实例教程中慢满体会xml的强大优势吧!
四. xml很难学吗?
如果你有兴趣学习xml,不禁会问:xml难吗?学习xml需要什么样的基础?
xml非常简单,学习容易。如果你熟悉html,你会发现它的文档和html非常相似,看同样的示例文档(例1):
?xml version="1.0"?>
<myfile>
<title>xml quick start</title>
<author>ajie</author>
<email>ajie@aolhoo.com</email>
<date>20010115</date>
</myfile>
第一行是一个xml声明,表示文档遵循的是xml的1.0 版的规范。
第二行定义了文档里面的第一个元素(element),也称为根元素: < myfile>。这个就类似html里的< html>开头标记。注意,这个名称是自己随便定义的。
再下面定义了四个子元素:title,author,email,和date。分别说明文章的标题,作者,邮箱和日期。当然,你可以用中文来定义这些标签,看上去更便于理解:
<?xml version="1.0" encoding="gb2312"?>
<文章>
<标题>xml轻松学习手册</标题>
<作者>ajie</作者>
<信箱>ajie@aolhoo.com</信箱>
<日期>20010115</日期>
</文章>
这就是xml的文档,任何掌握html的网友都可以直接写出这样简单的xml文档。
另外,学习xml还必须掌握一种页面脚本语言,常见的就是javascript和vb script。因为xml数据是使用script实现html中调用和交互的。我们看一个最简单的例子(例2):
1.将下面代码存为myfile.htm
<html>
<head>
<script language="javascript" for="window" event="onload">
var xmldoc = new activexobject("microsoft.xmldom");
xmldoc.async="false";
xmldoc.load("myfile.xml");
nodes = xmldoc.documentelement.childnodes;
title.innertext = nodesitem(0).text;
author.innertext = nodes.item(1).text;
email.innertext = nodes.item(2).text;
date.innertext = nodes.item(3).text;
</script>
<title>在html中调用xml数据</title>
</head>
<body bgcolor="#ffffff">
<b>标题: </b>
<span id="title"> </span>
<b>作者: </b>>
<span id="author"></span>
<b>信箱: </b>
<span id="email"></span>
<b>日期:</b>
<span id="date"></span>
</body>
</html>
2.将下面代码存为myfile.xml
<?xml version="1.0" encoding="gb2312"?>
<myfile>
<title>xml轻松学习手册</title>
<author>ajie</author>
<email>ajie@aolhoo.com</email>
<date>20010115</date>
</myfile>
3.将它们放在同一个目录下,用ie5以上版本浏览器打开,可以看到效果。 学习并掌握一种script,你将真正了解到xml无比的强大的功能。
五. xml和html的区别
xml和html都来自于sgml,它们都含有标记,有着相似的语法,html和xml的最大区别在于:html是一个定型的标记语言,它用固有的标记来描述,显示网页内容。比如< h1>表示首行标题,有固定的尺寸。相对的,xml则没有固定的标记,xml不能描述网页具体的外观,内容,它只是描述内容的数据形式和结构。
这是一个质的区别:网页将数据和显示混在一起,而xml则将数据和显示分开来。
我们看上面的例子,在myfile.htm中,我们只关心页面的显示方式,我们可以设计不同的界面,用不同的方式来排版页面,但数据是储存在myfile.xml中,不需要任何改变。
(如果你是程序员,你会惊讶的发现,这与模块化面向对象编程的思想极其相似!其实网页何尝不是一种程序呢?)
正是这种区别使得xml在网络应用和信息共享上方便,高效,可扩展。所以我们相信,xml做为一种先进的数据处理方法,将使网络跨越到一个新的境界。
首先有两点是需要肯定的:
第一:xml肯定是未来的发展趋势,不论是网页设计师还是网络程序员,都应该及时学习和了解,等待只会让你失去机会;
第二:新知识肯定会有很多新概念,尝试理解和接受,您才可能提高。不要害怕和逃避,毕竟我们还年轻。
提纲
本文共分五大部分。分别是xml快速入门,xml的概念,xml的术语,xml的实现,xml的实例分析。最后附录介绍了xml的相关资源。作者站在普通网页设计人员的角度,用平实生动的语言,向您讲述xml的方方面面,帮助你拨开xml的神秘面纱,快速步入xml的新领域。
xml初学者普遍存在的问题
1。xml是什么?(不要说是可扩展的标记语言之类的话)
2。xml可以做什么?怎么做?(不需要回答,只需要列举出一个简单的例子即可)
1: xml,是用来描迷数据的.
2:举一个例子说明:有a数据库 b数据库,他们之间的标准不同,不能互传.那么你可以把数据放在xml中,而后就可以让a,b之间可以共同传输数据了.
补充:
首先要有一个概念,你最好不要去用xml设计网页,不是说不可以, 只是要说明,xml不是html的替代.
有了这个概念,就不会有很多的看完一个一个的教程,还不知道xml做什么,很明了
xml就是为了描述数据
开始学习xml:
1.工具:xmlspy2005,
2.学习xml从那里开始?
即我要说明的是:先写xml还是先写dtd或是xml schemas.
大多的教程从xml说起,再说dtd...再说xml schemas...
不过我个人觉的,先了解一下xml的基本语法,而后跳过dtd,从schemas开始.
这样不会让dtd搞的没兴趣..而后再对dtd作一定了解.这里要说明,我觉的先写
好一个schemas再写xml比较好.即,先建立模型.再去填数据.
第一章:xml快速入门
一. 什么是xml?
二. xml是新概念吗?
三. 使用xml有什么好处?
四. xml很难学吗?
五. xml和html的区别
六. xml的严格格式
七. 关于xml的更多
一. 什么是xml?
这往往是第一个问题,也往往在第一个问题上你就会搞不明白,因为大多的教材上这样回答:
xml是extensible markup language的简写,一种扩展性标识语言。 这是标准的定义。那么什么是标志语言,为什么叫扩展性?已经让人有些糊涂。我想我们这样来理解会好一些:
对html你已经非常熟悉了吧,它就是一种标记语言,记得它的全称吗:"hypertext markup language" 超文本标记语言。明白了?同时,html里面有很多标签,类似,等,都是在html
4.0里规范和定义,而xml里允许你自己创建这样的标签,所以叫做可扩展性。
这里有几个容易混淆的概念要提醒大家:
1.xml并不是标记语言。它只是用来创造标记语言(比如html)的元语言。天,又糊涂了!不要紧,你只要知道这一点:xml和html是不一样的,它的用处途比html广泛得多,我们将在后面仔细介绍。
2.xml并不是html的替代产品。xml不是html的升级,它只是html的补充,为html扩展更多功能。我们仍将在较长的一段时间里继续使用html。(但值得注意的是html的升级版本xhtml的确正在向适应xml靠拢。)
3.不能用xml来直接写网页。即便是包含了xml数据,依然要转换成html格式才能在浏览器上显示。
下面就是一段xml示例文档(例1),用来表示本文的信息:
<myfile>
<title>xml quick start</title>
<author>ajie</author>
<email>ajie@aolhoo.com</email>
<date>20010115</date>
</myfile>
注意:
1.这段代码仅仅是代码,让你初步感性认识一下xml,并不能实现什么具体应用;
2.其中类似< title>,< author>的语句就是自己创建的标记(tags),它们和html标记不一样,例如这里的< title>是文章标题的意思,html里的< title>是页面标题。
二. xml是新概念吗?
不是。xml来源于sgml,一种比html更早的标志语言标准。
关于sgml,我们来简单了解一下,你只需要有个大致概念就可以。
sgml全称是"standard generalized markup language"(通用标识语言标准)。看名称就知道:它是标志语言的标准,也就是说所有标志语言都是依照sgml制定的,当然包括html。sgml的覆盖面很广,凡是有一定格式的文件都属于sgml,比如报告,乐谱等等,html是sgml在网络上最常见的文件格式。因此,人们戏称sgml是html的"妈妈"。
而xml就是sgml的简化版,只不过省略了其中复杂和不常用的部分。(哦,明白了!是html第二个"mother",难怪比html功能强大呢。),和sgml一样,xml也可以应用在金融,科研等各个领域,我们这里讲的,只是xml在web方面的运用而已。
到这里,你应该有点明白了:xml是用来创建定义类似html的标记语言,然后再用这个标记语言来显示信息。 三. 使用xml有什么好处?
有了html,为什么还需要用xml?
因为现在网络应用越来越广泛,仅仅靠html单一文件类型来处理千变万化的文档和数据已经力不丛心,而且html本身语法十分不严密,严重影响网络信息传送和共享。(想想浏览器兼容的问题伤透多少设计师的脑细胞啊。)人们早已经开始探讨用什么方法来满足网络上各种应用的需要。使用sgml是可以的,但sgml太庞大,编程复杂,于是最终选择了"减肥"的sgml---xml作为下一代web运用的数据传输和交互的工具。
使用xml有什么好处?来看w3c组织(xml标准制定者)的说明:
xml使得在网络上使用sgml语言更加"简单和直接": 简化了定义文件类型的过程,简化了编程和处理sgml文件的过程,简化了在web上的传送和共享。
1.xml可以广泛的运用于web的任何地方;
2.xml可以满足网络应用的需求;
3.使用xml将使编程更加简单;
4.xml便于学习和创建;
5.xml代码将清晰和便于阅读理解;
还是抽象了些。让我们在后面的实例教程中慢满体会xml的强大优势吧!
四. xml很难学吗?
如果你有兴趣学习xml,不禁会问:xml难吗?学习xml需要什么样的基础?
xml非常简单,学习容易。如果你熟悉html,你会发现它的文档和html非常相似,看同样的示例文档(例1):
?xml version="1.0"?>
<myfile>
<title>xml quick start</title>
<author>ajie</author>
<email>ajie@aolhoo.com</email>
<date>20010115</date>
</myfile>
第一行是一个xml声明,表示文档遵循的是xml的1.0 版的规范。
第二行定义了文档里面的第一个元素(element),也称为根元素: < myfile>。这个就类似html里的< html>开头标记。注意,这个名称是自己随便定义的。
再下面定义了四个子元素:title,author,email,和date。分别说明文章的标题,作者,邮箱和日期。当然,你可以用中文来定义这些标签,看上去更便于理解:
<?xml version="1.0" encoding="gb2312"?>
<文章>
<标题>xml轻松学习手册</标题>
<作者>ajie</作者>
<信箱>ajie@aolhoo.com</信箱>
<日期>20010115</日期>
</文章>
这就是xml的文档,任何掌握html的网友都可以直接写出这样简单的xml文档。
另外,学习xml还必须掌握一种页面脚本语言,常见的就是javascript和vb script。因为xml数据是使用script实现html中调用和交互的。我们看一个最简单的例子(例2):
1.将下面代码存为myfile.htm
<html>
<head>
<script language="javascript" for="window" event="onload">
var xmldoc = new activexobject("microsoft.xmldom");
xmldoc.async="false";
xmldoc.load("myfile.xml");
nodes = xmldoc.documentelement.childnodes;
title.innertext = nodesitem(0).text;
author.innertext = nodes.item(1).text;
email.innertext = nodes.item(2).text;
date.innertext = nodes.item(3).text;
</script>
<title>在html中调用xml数据</title>
</head>
<body bgcolor="#ffffff">
<b>标题: </b>
<span id="title"> </span>
<b>作者: </b>>
<span id="author"></span>
<b>信箱: </b>
<span id="email"></span>
<b>日期:</b>
<span id="date"></span>
</body>
</html>
2.将下面代码存为myfile.xml
<?xml version="1.0" encoding="gb2312"?>
<myfile>
<title>xml轻松学习手册</title>
<author>ajie</author>
<email>ajie@aolhoo.com</email>
<date>20010115</date>
</myfile>
3.将它们放在同一个目录下,用ie5以上版本浏览器打开,可以看到效果。 学习并掌握一种script,你将真正了解到xml无比的强大的功能。
五. xml和html的区别
xml和html都来自于sgml,它们都含有标记,有着相似的语法,html和xml的最大区别在于:html是一个定型的标记语言,它用固有的标记来描述,显示网页内容。比如< h1>表示首行标题,有固定的尺寸。相对的,xml则没有固定的标记,xml不能描述网页具体的外观,内容,它只是描述内容的数据形式和结构。
这是一个质的区别:网页将数据和显示混在一起,而xml则将数据和显示分开来。
我们看上面的例子,在myfile.htm中,我们只关心页面的显示方式,我们可以设计不同的界面,用不同的方式来排版页面,但数据是储存在myfile.xml中,不需要任何改变。
(如果你是程序员,你会惊讶的发现,这与模块化面向对象编程的思想极其相似!其实网页何尝不是一种程序呢?)
正是这种区别使得xml在网络应用和信息共享上方便,高效,可扩展。所以我们相信,xml做为一种先进的数据处理方法,将使网络跨越到一个新的境界。
上一篇: 设计模式之外观模式(Facade)
下一篇: 设计模式-装饰者模式