导读:在前面介绍了很多关于XML和HTML的东西,他们其实各有各的好处,在很多时候都需要结合起来使用。现在已经有XML和HTML结合的产物:XHTML(可扩展超文本标记语言)。在本篇博客中,则主要介绍通过引入命名空间的方法,进行XML和HTML混合使用的例子。
一、在XML中使用HTML
1.1,代码
<span style="font-family:KaiTi_GB2312;font-size:18px;"><?xml version="1.0" encoding="UTF-8"?> <?xml-stylesheet type="text/css"?> <!--HTML命名空间声明--> <body xmlns:html="http://www.w3.org/TR/RCE-html40"> <html:h2 align="center">Angel测试XML中的HTML<html:hr></html:hr></html:h2> <content> <h1 align="center">XML中的h1标签</h1> <html:h1 align="center">HTML中的h1标签</html:h1> </content> </body></span>
1.2,说明
在<body xmlns:html="http://www.w3.org/TR/RCE-html40">中,引入了HTML的命名空间,所以在XML文档中,通过增加前缀HTML,就可以使用HTML的标签和语法。如果,没有这句话,则会出现下面的结果:
二、在HTML中使用XML
2.1,代码
<span style="font-family:KaiTi_GB2312;font-size:18px;"><!--XML命名空间声明--> <html xmlns:test> <head> <Meta http-equiv="Content-Type" content="text/html;charset=utf-8"/> <title>测试HTML中的XML</title> <body> <h1 align="center">测试HTML中XML使用</h1> <hr></hr> <test:text style="display:block;position:relative;font-size:30;color:red;">这是XML标签的内容</test:text> </body> </head></span>
2.2,说明
在<html xmlns:test>中,引入了xml的命名空间test,在代码中使用<test:text><./test:text>,而不是<text><./text>,是在告诉浏览器test并不是HTML的标记,是一个自定义的标记,所以浏览器会根据style属性设置的样式来显示text标记中定义的内容。如果没有前缀,那么浏览器会根据默认的格式来显示它,因为<text><./text>并不属于HTML标记。
没有前缀的效果:
三、扩展:数据岛
在HTML文档中使用<XML></XML>标记来嵌入xml数据时,就在HTML文档中形成了一个XML数据岛(data island)。数据岛是指存在于HTML页面中的xml代码。数据岛允许在HTML页面中集成XML,对于XML编写脚本,不需要通过脚本或<OBJECT>标签读取XML。几乎所有能够存在于一个结构完整的XML文档中的数据都能存在于一个数据岛中,包括处理指示、DOCTYPE声明和内部子集。
使用数据岛最为方便的方法是将XML数据保存为单独的XML文档,然后用<xml src="XML文档名称">。注意:编码串不能放在数据岛中。
四、总结
XML和HTML文档的混合使用,都是在各自的文档中引入对方的命名空间,从而进行操作。这就和做系统时的命名空间是一样的,当我们引入了一个命名空间后,就可以调用里面的方法。后续会接着深入的学习Schema文件和XPath语言等,有所收获的时候,会接着总结。接下来会了解一下XHTML,以及URI、URN、URL等基本知识点。