0

0

使用XML实现BBS(主题列表篇)的详情介绍

黄舟

黄舟

发布时间:2017-03-04 17:12:33

|

1787人浏览过

|

来源于php中文网

原创

表a:

1-0-1,this is a test 
  3-1-1,this is a test 
  4-3-1,this is a test 
  5-3-1,this is a test 
  2-0-2,this is a test

  上面是BBS主题列表的一个例子。一般来说,假如不是使用Oracle(Oracle 有一条查询语句可以自动生成家族树,请查阅Select ... startwith ... connect by ...语句),那么如何实现上例的列表是一件费事的工作(相信许多程序员都写过)。
  如果我们改用xml来实现,那么结果会怎么样呢?
  现在我们使用"Select * from bbs"从数据库中查询贴子,并以XML格式返回(如果你是用ADO,那么可以用其RecordSet.Save ... adPersistXML直接生成,当然如果你不喜欢ADO生成的格式,可用程序生成,如本例):
  表B:
  


  
  
  
  4-3-1,this is a test
  slddfjslajfsdljf
  
  
  5-3-1,this is a test
  slddfjslajfsdljf
  
  
  3-1-1,this is a test
  slddfjslajfsdljf
  
  
  1-0-1,this is a test
  slddfjslajfsdljf
  
  
  2-0-2,this is a test
  slddfjslajfsdljf
  
  

  说明:这里sid是贴子的id号,pid是贴子的父id号。title是标题,content是贴子的内容。
  上表中第二行是指定使用b.XSL来转换XML内容。这是提供给IE5的信息。假如你使用XMLDOM,那么可以不要这条信息。
  我们再来看看将上表的XML内容显示成表A形式的XSL文件是怎么实现的:
  表C:b.XSL
  


  
  
  
  
   
  
  
  
  
  
  •   
                           
      
  •   
         
           
      
      

      现在,你将表B的内容存为abc.xml,将表C的内容存为b.xsl,然后在IE5中打开,你就可以看到和表A一样的内容了。
      因此可以看出,XSL文件解定了最终的显示结果。假如你有多个子论坛,那么无需更改论坛程序,只要为各个子论坛提供不同XSL文件,就可以让各个子论坛的版而不论风格画面还是主题排列都会具有独特的表现。如果提供免费论坛服务,那么允许论坛申请者定制自已的XSL文件将是一个良好的选择。
      但是假如客户端不支持XML,该怎么办呢?答案很简单,由服务端先将XML转换成HTML,再传到客户端。
      下面我们以IIS4/5+IE5+asp来实现这个例子(服务器必需安装IE5):
      

    arXiv Xplorer
    arXiv Xplorer

    ArXiv 语义搜索引擎,帮您快速轻松的查找,保存和下载arXiv文章。

    下载
    <%@ LANGUAGE = JScript %>
      <%
      Set rsXML=Server.CreateObject("ADODB.RecordSet");
      sSQL = “SELECT * from bbs"
      sConn = “你自个儿写”
      rsXML.CursorLocation = adUseClient
      rsXML.Open sSQL, sConn, adOpenStatic
      //指定XSL文件位置
      var styleFile = Server.MapPath("simple.xsl");
      // Save the XML to XMLDOM
      var source = Server.CreateObject("Microsoft.XMLDOM");
      ''rsXML.Save source, adPersistXML
      ''我相当不喜欢ADO直接Save出来的XML文档,我总是这样做:
      Dim GetData,v
      GetData = GetData & ""
      while not RS_ForumInfo.EOF 
      GetData = GetData & ""
      for i = 0 to RS_ForumInfo.Fields.Count -1
      set v = RS_ForumInfo.Fields.Item(i)
      if (v.Type=201)or(v.Type=203)or(v.Type=205) then
      GetData = GetData& "<" & RS_ForumInfo.Fields.Item(i).Name &">" &_
      "" &_
      ""
      else
      GetData = GetData& "<" & RS_ForumInfo.Fields.Item(i).Name &">" &_
      RS_ForumInfo.Fields.Item(i).Value &_
      ""
      end if
      set v = Nothing
      next
      GetData = GetData & ""
      RS_ForumInfo.MoveNext
      wend
      GetData = GetData & ""
      source.loadXML GetData
      // Load the XSL
      var style = Server.CreateObject("Microsoft.XMLDOM");
      style.async = false;
      style.load(styleFile);
      Response.Write(source.transformNode(style));
      %>

      当然,由于此处为了简便,直接使用ADO来生成XML,因此simple.xsl和上面的b.xsl是不同的。
      读者可以参考上例和XSL参考资料(2000年的MSDN有比较详细的XML/XSL SDK文档)来编写。(完) 

     以上就是使用XML实现BBS(主题列表篇)的详情介绍的内容,更多相关内容请关注PHP中文网(www.php.cn)!

    相关专题

    更多
    php源码安装教程大全
    php源码安装教程大全

    本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

    65

    2025.12.31

    php网站源码教程大全
    php网站源码教程大全

    本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

    43

    2025.12.31

    视频文件格式
    视频文件格式

    本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

    35

    2025.12.31

    不受国内限制的浏览器大全
    不受国内限制的浏览器大全

    想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

    41

    2025.12.31

    出现404解决方法大全
    出现404解决方法大全

    本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

    204

    2025.12.31

    html5怎么播放视频
    html5怎么播放视频

    想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

    9

    2025.12.31

    关闭win10系统自动更新教程大全
    关闭win10系统自动更新教程大全

    本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

    8

    2025.12.31

    阻止电脑自动安装软件教程
    阻止电脑自动安装软件教程

    本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

    3

    2025.12.31

    html5怎么使用
    html5怎么使用

    想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

    2

    2025.12.31

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    XML教程
    XML教程

    共142课时 | 5.4万人学习

    XQuery 教程
    XQuery 教程

    共12课时 | 3.4万人学习

    XLink  教程
    XLink 教程

    共7课时 | 1.1万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号