| 加入收藏| 设为首页| 联系我们

首页 站长学习 站长之家 源码下载 建站素材 书籍教程 常用工具
 您现在的位置: 动力中国 >> 网络编程 >> Ajax教程 >> 文章正文  
 Ajax实现分页查询
 

Ajax实现分页查询

http://www.domcn.org  文章来源:本站原创  点击数:

  关键字:Ajax实现分页查询

 

由于查询返回的数据量很大,超过10w条数据,因此需要对页面查询功能进行优化。放弃原有程序中使用DataGrid的做法,自己编写分页显示模块。
    首先在页面上添加几个DIV:
   
    <div id=div_trackpoint style= border:solid 1px gray; height:230px; width:99%; overflow-y:auto;>用于显示查询回的数据</div>
    <div id=div_trackpages style= height:15px; width:99%; font-size:8pt; word-break:break-all; word-wrap: break-word;>用于显示分页的页码</div><br />
    <div id=div_trackpagetab style= height:15px; width:99%; font-size:8pt; text-align:center;>用于显示前一页、后一页、...、首页、尾页等控制按钮</div>
    <div id=div_trackpage_status style= height:20px; width:99%; font-size:8pt; text-align:center;>用于显示当前页的页码</div>

    实现客户端分页函数:
    var CurPage=0;                          //当前页
    var TotalPage=0;                        //总页数
    var PageTab=7;                          //每组显示页数
    var CurTab=0;                           //当前分组
   
    我的程序是设置每页显示50条数据,每组显示7页,这些可以按需求调整。

    TurnTab函数用于切换分组,根据传入的val来计算显示哪一组页面。val=1表示切换到下一组,val=-1表示切换到上一组,0表示切换到第一组,-2表示切换到最后一组。用户通过单击页面上的  ...  符号来切换分组。

function TurnTab(val)
{
    var nPage = 0;
   
    if (val == 1) {
        CurTab++;
        nPage = (CurTab - 1) * PageTab + 1; 
    }
    else if (val == -1) {
        CurTab--;
        nPage = (CurTab - 1) * PageTab + 1;
    }
    else if (val == 0) {
        CurTab = 1;
        nPage = 1;
    }
    else if (val == -2) {
        CurTab = Math.floor(TotalPage / PageTab) + 1;
        nPage = (CurTab - 1) * PageTab + 1;
    }
       
    var carinfo = document.getElementById(div_trackpages);
    var tabinfo = document.getElementById(div_trackpagetab);

    var strInner = ;
   
    strInner += <a href=\javascript:TurnPage(1)\>首页</a>&nbsp;;
   
    strInner += <a href=\javascript:PreviousPage()\>前一页</a>&nbsp;;
   
    strInner += 总共 + TotalPage + 页&nbsp;;
   
    strInner += <a href=\javascript:NextPage()\>下一页</a>&nbsp;;
   
    strInner += <a href=\javascript:TurnPage( + TotalPage + )\>尾页</a>&nbsp;;
   
    tabinfo.innerHTML = strInner;
   
    strInner = ;
   
    if (CurTab > 1) strInner += <a href=\javascript:TurnTab(-1)\>...</a>&nbsp;;
   
    for ( ; nPage<=CurTab*PageTab; nPage++) {
       
        if (nPage <= TotalPage) {
           
            strInner += <a href=\javascript:TurnPage(+ nPage + )\>+nPage+</a>&nbsp;
           
        }
    }
   
    if (nPage < TotalPage) strInner += <a href=\javascript:TurnTab(1)\>...</a>&nbsp;;
   
    carinfo.innerHTML = strInner;
   
}

    TurnPage函数用于切换分页,val表示要切换到的页数,根据要显示的页数生成查询范围,如查询前50条记录,从51到100的记录,从101到150的记录。。。
    cscCustomAnalyst是一个异步调用函数,函数实现的代码将在下面贴出。Method,SID, TIME1, TIME2, ROW1, ROW2都是执行查询所需的参数,Method是用来判断要执行什么查询,ROW1, ROW2表示要查询的记录范围,其他的参数就根据实际需要进行调整。ShowCarTrack(val)是一个对查询结果进行处理的函数,异步调用完成后得到的结果就将在这个函数中分析处理并且显示。这部分代码按照具体实现编写,我这里就不列出。

function TurnPage(val)
{
    if (Number(val) != CurPage) {
   
        CurPage = Number(val);
       
        var row1 = String((CurPage - 1) * 50 + 1);
        var row2 = String(CurPage * 50);
       
        var trackinfo = document.getElementById(div_trackpoint);
        trackinfo.innerHTML =   获取数据中,请稍等...;
       
        _cscCustomAnalyst([Method, SID, TIME1, TIME2, ROW1, ROW2],
                            [GetCarTrack,, 80100117, t1, t2, row1, row2],
                    ShowCarTrack,onQueryError);
                   
        if (CurPage == 1) TurnTab(0);
       
        if (CurPage == TotalPage) TurnTab(-2);   
       
        var statusinfo = document.getElementById(div_trackpage_status);
       
        statusinfo.innerHTML = 第 + CurPage  + 页;
    }

}

    NextPage切换下一页,调用TurnPage实现,如果下一页超出当前分组则要切换到下一分组。

function NextPage()
{
    if (CurPage < TotalPage) {
   
        TurnPage(CurPage+1);
       
        if ((CurPage + 1) > (CurTab * PageTab)) {
            TurnTab(1);
        }
    }
   
}

    PreviousPage切换上一页,调用TurnPage实现,如果上一页超出当前分组则要切换到上一分组。
function PreviousPage()
{
    if (CurPage > 1) {

        TurnPage(CurPage-1);
       
        if ((CurPage - 1) <= ((CurTab - 1) * PageTab)) {
            TurnTab(-1);
        }
       
    }
}

    _cscCustomAnalyst是异步调用函数,xhr.open(post,MapQuery.ashx, true);这段话是表示将请求提交到MapQuery.ashx这个页面。所有的服务器段数据库操作都在MapQuery.ashx里面执行。

function _cscCustomAnalyst(paramNames, paramValues, onComplete, onError){
   
    var xhr=_GetXmlHttpRequest();
   
    xhr.open(post,MapQuery.ashx, true);

    xhr.setRequestHeader(Content-Type, application/x-www-form-urlencoded);
   
    xhr.onreadystatechange=function(){
   
        var readyState=xhr.readyState;
       
        if (readyState==4){
       
            var status=xhr.status;
           
            if(status==200){
           
                   var resultset = xhr.responseText;
                  
                if(resultset == null){
                    onComplete(null);
                    return;
                }

                if(onComplete){

[1] [2] 下一页


Ajax实现分页查询
  • 上一篇文章:

  • 下一篇文章:
  •  热门文章
    普通文章 电子邮件改头换面 四公司畅谈未
    普通文章 PC病毒史上最声名狼藉的八大病
    普通文章 Rails系统中的AJAX开发技术简析
    普通文章 基于ASP.NET AJAX框架实现表单
    普通文章 开发ASP.NET AJAX客户端定制行
    普通文章 用JFreeChart对JSP报表进行增强
    普通文章 SQL Server 2005上的CLR和ADO.
    普通文章 SQL Server 2005的XML支持机制
    普通文章 Firefox中标签式浏览技巧大全
    普通文章 Tomcat中的Session和Cookie大揭
     
     推荐文章
    推荐文章 把Google地图嵌入网页 就是这么
    推荐文章 迅雷搜索候选资源出错的解决
    推荐文章 轻松去除迅雷里的各种广告和资
    推荐文章 突破限制 免费领养到QQ空间五级
    推荐文章 Rational统一过程RUP贴近中小软
    推荐文章 构建自己的轻量级XML DOM分析程
    推荐文章 WPS Office 2007技巧:妙用配置
    推荐文章 Excel 2007:求余数函数实用进阶
    推荐文章 浅谈ASP.NET的Postback
    推荐文章 软件开发中项目需求管理简述
     
     相关文章
    没有相关文章
    设为首页 | 加入收藏 | 广告合作 | 联系站长 | 版权申明 |
    动力中国为网友提供免费学习资料,可用资源,如果您认为我们的相关内容侵害到了您的权利请联系管理员
    Copyright © 2006-2008 domcn.org All Rights Reserved.