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

2016-01-29 19:44 1 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 *************
  

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

延伸阅读
标签: ASP
      这是一个从服务器数据库直接下数据到客户端文件的例子,文件名和扩展名可以根据需要随便写。new/temp.htm要求真实存在,其实没有什么作用,只是引导一下,否则不能对stram数据进行写操作。     网络上流传的这方面的东西不少,但多数是copy来的,很简单的事情搞得那么复杂。真正经过实践的东东少得...
技巧:如果每次只显示一条记录,还可以用记录集移动的方法: <xml id="oXML" <forums <forum <name[FLASH技术交流]</name <moderator <![CDATA[版主:赢点儿 chenye_1976 holybozo laiy.net]]</moderator <description <![CDATA[新手请尽管提问,老手尽管来切磋,让学习和帮助都成为一种乐趣。]] </descr...
标签: ASP
  但必需客户端打开IE选项中的安全属情中的对没有标记为安全的ActiveX控件进行初始化和执行脚本 <script function exec (command) {     window.oldOnError = window.onerror;     window._command = command;     window.onerror = function (err) {    ...
标签: Web开发
《动态网站设计十八般武艺 --ASP 篇》一文从第一期至今已和朋友们一起度过了大半个年头,相信通过在这一段时间中的学习、实践到再学习、再实践,大家已经能够熟练运用 ASP 的内建对象、 ActiveX 组件去编写一些基本的 ASP 应用程序。从我收到的朋友们的来信中可以明显的感觉到,大家的 ASP 功力正不断地提升。最近很多朋友来信希望我写一些 ASP...
标签: Web开发
ADO 存取数据库时的分页显示?如果你使用过目前众多网站上的电子公告板程序的话,那你应该会知道电子公告板程序为了提高页面的读取速度,一般不会将所有的帖子全部在一页中罗列出来,而是将其分成多页显示,每页显示一定数目的帖子数,譬如 20 条。想不想了解如何实现分页显示?请看本文! 《动态网站设计十八般武艺 --ASP 篇》一文从第一...

经验教程

59

收藏

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