ajax div 分页

Ajax实现分页查询

[ 作者: 加入时间:2007-11-12 16:44:53 来自:Linux联盟收集整理 ]



xxlinux.com
由于查询返回的数据量很大,超过10w条数据,因此需要对页面查询功能进行优化。放弃原有程序中使用DataGrid的做法,自己编写分页显示模块。 yTPLinux联盟
首先在页面上添加几个DIV: yTPLinux联盟
yTPLinux联盟
<div id="div_trackpoint" style=" border:solid 1px gray; height:230px; width:99%; overflow-y:auto;">用于显示查询回的数据</div> yTPLinux联盟
<div id="div_trackpages" style=" height:15px; width:99%; font-size:8pt; word-break:break-all; word-wrap: break-word;">用于显示分页的页码</div><br /> yTPLinux联盟
<div id="div_trackpagetab" style=" height:15px; width:99%; font-size:8pt; text-align:center;">用于显示前一页、后一页、...、首页、尾页等控制按钮</div> yTPLinux联盟
<div id="div_trackpage_status" style=" height:20px; width:99%; font-size:8pt; text-align:center;">用于显示当前页的页码</div> yTPLinux联盟
yTPLinux联盟
实现客户端分页函数: yTPLinux联盟
var CurPage=0; //当前页 yTPLinux联盟
var TotalPage=0; //总页数 yTPLinux联盟
var PageTab=7; //每组显示页数 yTPLinux联盟
var CurTab=0; //当前分组 yTPLinux联盟
yTPLinux联盟
我的程序是设置每页显示50条数据,每组显示7页,这些可以按需求调整。 yTPLinux联盟
yTPLinux联盟
TurnTab函数用于切换分组,根据传入的val来计算显示哪一组页面。val=1表示切换到下一组,val=-1表示切换到上一组,0表示切换到第一组,-2表示切换到最后一组。用户通过单击页面上的 ... 符号来切换分组。 yTPLinux联盟
yTPLinux联盟
function TurnTab(val) yTPLinux联盟
{ yTPLinux联盟
var nPage = 0; yTPLinux联盟
yTPLinux联盟
if (val == 1) { yTPLinux联盟
CurTab++; yTPLinux联盟
nPage = (CurTab - 1) * PageTab + 1; yTPLinux联盟
} yTPLinux联盟
else if (val == -1) { yTPLinux联盟
CurTab--; yTPLinux联盟
nPage = (CurTab - 1) * PageTab + 1; yTPLinux联盟
} yTPLinux联盟
else if (val == 0) { yTPLinux联盟
CurTab = 1; yTPLinux联盟
nPage = 1; yTPLinux联盟
} yTPLinux联盟
else if (val == -2) { yTPLinux联盟
CurTab = Math.floor(TotalPage / PageTab) + 1; yTPLinux联盟
nPage = (CurTab - 1) * PageTab + 1; yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
var carinfo = document.getElementById("div_trackpages"); yTPLinux联盟
var tabinfo = document.getElementById("div_trackpagetab"); yTPLinux联盟
yTPLinux联盟
var strInner = ""; yTPLinux联盟
yTPLinux联盟
strInner += "<a href=\"javascript:TurnPage(1)\">首页</a> "; yTPLinux联盟
yTPLinux联盟
strInner += "<a href=\"javascript:PreviousPage()\">前一页</a> "; yTPLinux联盟
yTPLinux联盟
strInner += "总共" + TotalPage + "页 "; yTPLinux联盟
yTPLinux联盟
strInner += "<a href=\"javascript:NextPage()\">下一页</a> "; yTPLinux联盟
yTPLinux联盟
strInner += "<a href=\"javascript:TurnPage(" + TotalPage + ")\">尾页</a> "; yTPLinux联盟
yTPLinux联盟
tabinfo.innerHTML = strInner; yTPLinux联盟
yTPLinux联盟
strInner = ""; yTPLinux联盟
yTPLinux联盟
if (CurTab > 1) strInner += "<a href=\"javascript:TurnTab(-1)\">...</a> yTPLinux联盟
yTPLinux联盟
"; yTPLinux联盟
yTPLinux联盟
for ( ; nPage<=CurTab*PageTab; nPage++) { yTPLinux联盟
yTPLinux联盟
if (nPage <= TotalPage) { yTPLinux联盟
yTPLinux联盟
strInner += "<a href=\"javascript:TurnPage("+ nPage + ")\">"+nPage+"</a> " yTPLinux联盟
yTPLinux联盟
} yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
if (nPage < TotalPage) strInner += "<a href=\"javascript:TurnTab(1)\">...</a> "; yTPLinux联盟
yTPLinux联盟
carinfo.innerHTML = strInner; yTPLinux联盟
yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
TurnPage函数用于切换分页,val表示要切换到的页数,根据要显示的页数生成查询范围,如查询前50条记录,从51到100的记录,从101到150的记录。。。 yTPLinux联盟
cscCustomAnalyst是一个异步调用函数,函数实现的代码将在下面贴出。"Method","SID", "TIME1", "TIME2", "ROW1", "ROW2"都是执行查询所需的参数,Method是用来判断要执行什么查询,"ROW1", "ROW2"表示要查询的记录范围,其他的参数就根据实际需要进行调整。ShowCarTrack(val)是一个对查询结果进行处理的函数,异步调用完成后得到的结果就将在这个函数中分析处理并且显示。这部分代码按照具体实现编写,我这里就不列出。 yTPLinux联盟
yTPLinux联盟
function TurnPage(val) yTPLinux联盟
{ yTPLinux联盟
if (Number(val) != CurPage) { yTPLinux联盟
yTPLinux联盟
CurPage = Number(val); yTPLinux联盟
yTPLinux联盟
var row1 = String((CurPage - 1) * 50 + 1); yTPLinux联盟
var row2 = String(CurPage * 50); yTPLinux联盟
yTPLinux联盟
var trackinfo = document.getElementById("div_trackpoint"); yTPLinux联盟
trackinfo.innerHTML = "  获取数据中,请稍等..."; yTPLinux联盟
yTPLinux联盟
_cscCustomAnalyst(["Method", "SID", "TIME1", "TIME2", "ROW1", "ROW2"], yTPLinux联盟
["GetCarTrack",, "80100117", t1, t2, row1, row2], yTPLinux联盟
ShowCarTrack,onQueryError); yTPLinux联盟
yTPLinux联盟
if (CurPage == 1) TurnTab(0); yTPLinux联盟
yTPLinux联盟
if (CurPage == TotalPage) TurnTab(-2); yTPLinux联盟
yTPLinux联盟
var statusinfo = document.getElementById("div_trackpage_status"); yTPLinux联盟
yTPLinux联盟
statusinfo.innerHTML = "第" + CurPage + "页"; yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
NextPage切换下一页,调用TurnPage实现,如果下一页超出当前分组则要切换到下一分组。 yTPLinux联盟
yTPLinux联盟
function NextPage() yTPLinux联盟
{ yTPLinux联盟
if (CurPage < TotalPage) { yTPLinux联盟
yTPLinux联盟
TurnPage(CurPage+1); yTPLinux联盟
yTPLinux联盟
if ((CurPage + 1) > (CurTab * PageTab)) { yTPLinux联盟
TurnTab(1); yTPLinux联盟
} yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
PreviousPage切换上一页,调用TurnPage实现,如果上一页超出当前分组则要切换到上一分组。 yTPLinux联盟
function PreviousPage() yTPLinux联盟
{ yTPLinux联盟
if (CurPage > 1) { yTPLinux联盟
yTPLinux联盟
TurnPage(CurPage-1); yTPLinux联盟
yTPLinux联盟
if ((CurPage - 1) <= ((CurTab - 1) * PageTab)) { yTPLinux联盟
TurnTab(-1); yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
} yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
_cscCustomAnalyst是异步调用函数,xhr.open("post","MapQuery.ashx", true);这段话是表示将请求提交到MapQuery.ashx这个页面。所有的服务器段数据库操作都在MapQuery.ashx里面执行。 yTPLinux联盟
yTPLinux联盟
function _cscCustomAnalyst(paramNames, paramValues, onComplete, onError){ yTPLinux联盟
yTPLinux联盟
var xhr=_GetXmlHttpRequest(); yTPLinux联盟
yTPLinux联盟
xhr.open("post","MapQuery.ashx", true); yTPLinux联盟
yTPLinux联盟
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); yTPLinux联盟
yTPLinux联盟
xhr.onreadystatechange=function(){ yTPLinux联盟
yTPLinux联盟
var readyState=xhr.readyState; yTPLinux联盟
yTPLinux联盟
if (readyState==4){ yTPLinux联盟
yTPLinux联盟
var status=xhr.status; yTPLinux联盟
yTPLinux联盟
if(status==200){ yTPLinux联盟
yTPLinux联盟
var resultset = xhr.responseText; yTPLinux联盟
yTPLinux联盟
if(resultset == null){ yTPLinux联盟
onComplete(null); yTPLinux联盟
return; yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
if(onComplete){ yTPLinux联盟
onComplete(resultset); yTPLinux联盟
resultset = null; yTPLinux联盟
} yTPLinux联盟
} yTPLinux联盟
else{ yTPLinux联盟
if(onError){ yTPLinux联盟
onError(xhr.responseText); yTPLinux联盟
} yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
xhr.onreadystatechange = function(){}; yTPLinux联盟
yTPLinux联盟
xhr = null; yTPLinux联盟
} yTPLinux联盟
}; yTPLinux联盟
yTPLinux联盟
var paramString=null; yTPLinux联盟
yTPLinux联盟
if(paramNames&¶mNames.length>0){ yTPLinux联盟
yTPLinux联盟
var params = new Array(); yTPLinux联盟
yTPLinux联盟
while(paramNames&¶mNames.length>0) yTPLinux联盟
{ yTPLinux联盟
params.push(paramNames.shift()+"="+_ToJSON(paramValues.shift())); yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
paramString = params.join("&"); yTPLinux联盟
yTPLinux联盟
} yTPLinux联盟
yTPLinux联盟
xhr.send(paramString); yTPLinux联盟
}; yTPLinux联盟
yTPLinux联盟
最后列出一个Oracle的按数量范围查询的SQL语句:(查询前50条记录) yTPLinux联盟
SELECT * yTPLinux联盟
FROM (SELECT /*+ FULL(tablename)*/ fieldname, ROWNUM rn FROM tablename WHERE condition AND ROWNUM <= 50 ORDER BY field DESC) t2 where t2.rn >= 1; yTPLinux联盟
xxlinux.com
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值