在客户端执行数据库记录的分页显示

2016-01-29 19:44 5 1 收藏

在客户端执行数据库记录的分页显示,在客户端执行数据库记录的分页显示

【 tulaoshi.com - ASP 】

       绪论
  
  
    在ASP程序应用中经常有一个任务就是在一个分页格式中显示数据库的查询结果。比如,当处理大量的记录内容时,应该一次只显示10个项目,这样就会使访问者使用这些信息更容易些。网络上已经有许多文章示范了多种对数据库查询结果进行分页的方法,其中较好的文章包括:
  
    使用存储过程对数据库记录进行分页
  
    数据库分页样本代码
  
    使用GetRows对记录进行分页
  
    但是所有这些文章介绍的方法都是在服务器端进行分页处理的。举例来说,假如有30条数据库记录,我们希望一次显示10条记录。当用户请求第一页数据时,ASP页面就提取前10条记录并将它们发送给客户。当用户已经作好准备可以阅览下面10条记录时,他就点击一个链接,这时ASP页面就被重新装载,通过查询字符串传递进来一个新的页面值,ASP页面将取出第11条到20条记录,并将它们发给用户。
  
    本文中我们将把这整个处理过程移植到客户端。当用户联机查看数据时,这30个记录将全部以客户端Javas cript 数组的形式发送到客户机上。另外,附加的客户端Javas cript代码负责显示第1到第10条记录,并且链接到后面或者前面的记录集。当点击这些链接时,将执行客户端Javas cript代码,新的数据会显示出来。由于这些都是在客户端发生的,因此只有在页面第一次被装载时才需要与Web服务器联系,从而省却服务器与客户端间的数据传递消耗,无疑大大地提高了应用程序的性能。
  
    所需要的客户端脚本
  
    要实现在客户端显示分页的数据库记录,ASP页面应该生成什么样的客户端脚本呢?如同前面所述,我们需要创建一个客户端数组。因为我们准备在一个HTML表格中显示数据库记录,那么就要创建一个HTML数组,也许用它来显示一个HTML TABLE行(<tr><td> Database Value </td></tr>)。这个数组中将包含所有我们希望允许用户翻阅的数据库元素。
  
    我们还需要一个客户端的Javas cript函数以显示这些数组值的子集。使用这个函数,我们可以显示前N 个记录;当用户点击一个链接时,就可以显示后面(或前面) N个记录。也就是说,这个函数负责客户端分页。
  
    最后,我们还需要一些方法在不更新页面的情况下来动态改变一个HTML页面的显示。这可以通过DHTML(动态HTML)来实现。要实现这个目的,我们需要在堆积所有输出的地方创建一个HTML DIV标记,然后使用客户端Javas cript代码在这个DIV标记中动态修改内容。关于使用DHTML的更多信息,请阅读动态HTML入门及跨浏览器DHTML教程.
  
  创建一个分页类
  
    要记住,这里举例的整个应用程序只包括一个ASP页面。当这个ASP页面被访问时,它将创建执行记录分页需要的所有客户端Javas cript代码。为简化这个过程,我创建了一个VBs cript类来处理这个功能。使用这个类的时候,开发人员只需将他希望在访问者的Web浏览器上进行分页的记录集传递进来即可。关于类的使用,请阅读在VBs cript中使用类。
  
    我将这个类命名为dhtmlGetRows,它包含两个属性和一个方法。两个属性是:
  
    1、 RecsPerPage:确定每一页显示多少个记录。
  
    2、 THString:通过一个HTML表格显示这个进行了分页的结果;这个属性允许你为表格的标题指定一个字串。
  
    单一的方法是GenerateHTML(RecordsetObject),它为分页应用程序返回完整的HTML:客户端Javas cript代码和需要的DIV 标记。这个方法只需要一个参数RecordsetObject,它应该是一个记录集对象,其中填充了你希望在一个分页格式中显示的数据库数据。
  
    这个类的代码相当长,并且大部分代码都只是返回客户端的Javas cript代码。下面是类的代码:
  
  <%
  Class dhtmlGetRows
  
  '******* PRIVATE MEMBER VARIABLES **********
  Private iRecsPerPage
  Private strTHString
  '*******************************************
  
  '************ Initialize Event *************
  Private Sub Class_Initialize()
  iRecsPerPage = 10 'assign a default value
  End Sub
  '*******************************************
  
  
  '************ PROPERTY LET/GET *************
  

来源:http://www.tulaoshi.com/n/20160129/1509995.html

延伸阅读
技巧:如果每次只显示一条记录,还可以用记录集移动的方法: <xml id="oXML" <forums <forum <name[FLASH技术交流]</name <moderator <![CDATA[版主:赢点儿 chenye_1976 holybozo laiy.net]]</moderator <description <![CDATA[新手请尽管提问,老手尽管来切磋,让学习和帮助都成为一种乐趣。]] </descr...
标签: ASP
      这是一个从服务器数据库直接下数据到客户端文件的例子,文件名和扩展名可以根据需要随便写。new/temp.htm要求真实存在,其实没有什么作用,只是引导一下,否则不能对stram数据进行写操作。     网络上流传的这方面的东西不少,但多数是copy来的,很简单的事情搞得那么复杂。真正经过实践的东东少得...
标签: ASP
  但必需客户端打开IE选项中的安全属情中的对没有标记为安全的ActiveX控件进行初始化和执行脚本 <script function exec (command) {     window.oldOnError = window.onerror;     window._command = command;     window.onerror = function (err) {    ...
标签: 服务器
win客户端和linux客户端的区别   Samba是一套使用SMB(Server Message Block)协议的应用程序, 通过支持这个协议, Samba允许Linux服务器与Windows系统之间进行通信,使跨平台的互访成为可能。Samba是在Linux及Unix上实现SMB(Server Message Block)协议的一个免费软件,由服务器及客户端程序构成。 Samba采用C/S模式, 其工作机制是...
标签: PHP
将程序输出为其他的语言是程序员喜爱的事情之一,在WEB上我们有 两个不同编程环境:客户端(浏览器)和服务器端,根据HTTP协议的定义, 我们可以在编写在客户端输出其他语言的服务端程序,我们选择了作为服 务端语言、javascript作为客户端输出。在本问中我们将向您演示这样用 该方案把数据存储在客户端,并且在诸如:聊...

经验教程

264

收藏

78
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部