小编给大家分享一下XML实现BBS的案例,希望大家阅读完这篇文章后大所收获、下面让我们一起去探讨吧!
表答:
1-0-1,这是一个测试 3-1-1,这是一个测试 4-3-1,这是一个测试 5-3-1,这是一个测试 2-0-2,这是一个测试
上面是论坛主题列表的一个例子。一般来说,假如不是使用甲骨文(Oracle有一条查询语句可以自动生成家族树,请查阅选择……startwith……connect by…语句),那么如何实现上例的列表是一件费事的工作(相信许多程序员都写过)。
如果我们改用xml来实现,那么结果会怎么样呢?
现在我们使用“Select * from bbs"从数据库中查询贴子,并以xml格式返回(如果你是用ADO,那么可以用其记录集。保存……adPersistXML直接生成,当然如果你不喜欢ADO生成的格式,可用程序生成,如本例):
表B:
& lt; ?xml version=?.0“?比; & lt; ?xml样式表类型=拔谋?xsl"href=https://www.yisu.com/zixun/癰.xsl”?><邮报sid=pid=?”“4”援助=" 1 "> <标题> 4-3-1,这是一个测试名称> <内容> slddfjslajfsdljf 内容> 后> <邮报sid=" 5 " pid=?”援助=" 1 "> <标题> 5-3-1,这是一个测试名称> <内容> slddfjslajfsdljf 内容> 后> <邮报sid=?”pid=?”援助=" 1 "> <标题> 3-1-1,这是一个测试名称> <内容> slddfjslajfsdljf 内容> 后> <邮报sid=?”pid=" 0 "援助=" 1 "> <标题> 1-0-1,这是一个测试名称> <内容> slddfjslajfsdljf 内容> 后> <邮报sid=" 2 " pid=" 0 "援助=" 2 "> <标题> 2-0-2,这是一个测试名称> <内容> slddfjslajfsdljf 内容> 后>
说明:这里席德是贴子的id号,pid是贴子的父id号.title是标题,内容是贴子的内容。
上表中第二行是指定使用b。XSL来转换XML内容。这是提供给IE5的信息。假如你使用XMLDOM,那么可以不要这条信息。
我们再来看看将上表的XML内容显示成表的形式的XSL文件是怎么实现的:
表C: b。XSL
& lt; ?xml version=& # 39; & # 39; 1.0 & # 39; & # 39; ?比; & lt; xsl:样式表xmlns: xsl=癶ttp://www.w3.org/TR/WD-xsl"比; & lt; xsl:模板匹配=?氨? & lt; html> & lt; body> & lt; xsl: apply - templates选择=?“/比; & lt;/body> & lt;/html> & lt;/xsl: template>=& lt; xsl:模板匹配“post"比; & lt; li> & lt; div> & lt; xsl:属性名称=皌itle"祝辞& lt; xsl:是选择=癱ontent"/祝辞& lt;/xsl: attribute> & lt; xsl:是选择=皌itle"/比; & lt; xsl:如果测试=?论坛/post ()/@sid] [@pid=上下文“比; & lt; xsl: element name=皍l"比; & lt; xsl: apply - templates选择=?论坛/post ()/@sid] [@pid=上下文“/比; & lt;/xsl: element> & lt;/xsl: if> & lt;/div> & lt;/li> & lt;/xsl: template>=& lt; xsl:模板匹配“bbs"比; & lt; ul> & lt; xsl: apply - templates选择=皃ost (@pid=0)“/比; & lt;/ul> & lt;/xsl: template> & lt;/xsl: stylesheet>
现在,你将表B的内容存为abc.xml,将表C的内容存为B。xsl,然后在IE5中打开,你就可以看到和表一个一样的内容了。
因此可以看的出,xsl文件解定了最终的显示结果假。如你有多个子论坛,那么无需更改论坛程序,只要为各个子论坛提供不同xsl文件,就可以让各个子论坛的版而不论风格画面还是主题排列都会具有独特的表现。如果提供免费论坛服务,那么允许论坛申请者定制自已的xsl文件将是一个良好的选择。
但是假如客户端不支持XML,该怎么办呢?答案很简单,由服务端先将XML转换成HTML,再传到客户端。
下面我们以IIS4/5 + IE5 + asp来实现这个例子(服务器必需安装IE5):
& lt; % @=JScript语言%比; & lt; % 设置rsXML=Server.CreateObject (“ADODB.RecordSet"); 从bbs" sSQL=" SELECT *; sConn="你自个儿写” rsXML。CursorLocation=adUseClient rsXML。开放sSQL、sConn adOpenStatic//指定XSL文件位置 var styleFile=Server.MapPath (“simple.xsl");//保存XML XMLDOM var=Server.CreateObject来源(“Microsoft.XMLDOM"); & # 39;& # 39;rsXML。保存源,adPersistXML & # 39;& # 39;我相当不喜欢ADO直接拯救出来的XML文档,我总是这样做: 昏暗的GetData, v GetData=https://www.yisu.com/zixun/GetData & "” 虽然不是RS_ForumInfo.EOF GetData=GetData & " <邮报>” 因为我RS_ForumInfo.Fields=0。数1 设置v=RS_ForumInfo.Fields.Item(我) 如果(v.Type=201)或(v.Type=203)或(v.Type=205) GetData=GetData " XML实现BBS的案例