用XML创建可排序、分页的数据显示页面

来源:孟宪会之精彩世界 时间:2008-04-22 18:25:00 

Web开发中,我们经常会遇到分页显示和排序数据记录集的情况,这在服务器端使用服务器端的代码和数据库技术是件很轻松的事情,比如:ASP、PHP、JSP等。然而,如果要在客户端显示多条记录并且排序是一件很令人头疼的事情。下面,我们利用Extensible Markup Language(XML,可扩展标记语言)和Extensible Stylesheet Language Transformations(XSLT,可扩展样式单语言转换),并结合XML Path Language(XPath,XML路径语言),只需要编写简单的代码,就可轻松实现。

这种方法避免了与服务器频繁打交道的过程,节省了数据显示的时间,浏览者无须等待就可以看到结果,也可以减少服务器的负担。另外。由于XML和XSLT技术,使数据存储和数据显示分离,还可以让我们的代码能够重复利用,大大减轻了程序员编写代码的负担。

下面,我们一步一步地来实现我们的功能。

首先:创建XSLT

XSLT样式单的第一行标明该XML所遵照的XML规范版本,然后是标明该样式单使用的名称空间,这里,我们以XSL规范的正式版本来进行编写,而不采用XSL的草案的写法:
   <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
   注意:两者在功能和写法上有很大的差异。
   <?xml version="1.0"?>
   <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
   接下来,我们定义XSLT里的模板标记:

   <xsl:template match="/">
   <xsl:apply-templates select="/客户关系表"/>
   </xsl:template>
   
   <xsl:template match="/客户关系表"></xsl:template>

我们把要显示的样式写到模板里面。我们使用HTML的数据岛来存放我们的数据,这些数据可以利用SQL Server 2000的XML查询来得到,对于不支持XML的数据库,我们可以自己编写组件把数据转换成XML格式,然后在放到数据岛里。在HTML里使用数据岛有两种方法:

一是直接嵌入数据,如下所示:

 <XML id=‘Data‘>
   <客户关系表>
   <客户>每条数据</客户>
   </客户关系表>
   </XML>

二是通过SRC属性引用外部文件,如下所示

<XML id=‘Data‘ src=‘Data.xml‘></XML>

要使用数据岛里的数据,必须通过id名来引用它,当然,由于XSLT文件也是XML格式文件的一种,也可以通过这种方法来实现:

   <XML id=‘Style‘ src=‘Style.xsl‘></XML>

 我们在页面中加入标记DIV来显示我们的转换的结果:
   

<div id="DisplayArea"></div>

使用XSLT转换数据岛里的数据,采用DOMDocument的transNode()方法,并把结果通过DIV的innerHTML属性来展现出来:
   

DisplayArea.innerHTML = Data.transformNode(Style.DocumentElement)

标签:xml,排序,数据
0
投稿

猜你喜欢

  • python3实现读取chrome浏览器cookie

    2023-10-18 13:18:44
  • GO语言Defer用法实例分析

    2024-04-23 09:49:01
  • python实现mp3文件播放的具体实现代码

    2023-02-03 13:37:52
  • 详解php实现页面静态化原理

    2023-10-25 10:58:10
  • python数据归一化及三种方法详解

    2023-02-28 01:48:40
  • BeautifulSoup获取指定class样式的div的实现

    2023-05-10 20:39:14
  • 对pycharm 修改程序运行所需内存详解

    2022-10-23 09:14:58
  • python tkinter实现界面切换的示例代码

    2023-12-29 15:54:35
  • python密码学库pynacl功能介绍

    2021-03-07 01:29:44
  • 详解vue3.0 的 Composition API 的一种使用方法

    2024-04-28 09:23:48
  • Python sklearn对文本数据进行特征化提取

    2023-05-19 09:07:04
  • python 图像增强算法实现详解

    2023-10-27 10:12:47
  • xmind2022下载非试用超详细图文教程

    2023-06-03 18:52:06
  • Golang 高效排序数据详情

    2023-06-23 08:23:41
  • MySQL中Distinct和Group By语句的基本使用教程

    2024-01-26 09:51:53
  • js中forEach,for in,for of循环的用法示例小结

    2024-04-29 13:20:16
  • Linux系统(CentOS)下python2.7.10安装

    2021-04-02 19:27:50
  • 浅析Python中MySQLdb的事务处理功能

    2024-01-14 01:23:10
  • 解决jupyter notebook import error但是命令提示符import正常的问题

    2022-08-19 22:10:30
  • django ajax json的实例代码

    2023-01-15 00:56:18
  • asp之家 网络编程 m.aspxhome.com